如果你的博客需要更换域名或地址,备份好你的数据库后,在cpanel进入“phpmy 管理”,然后选中你的博客所在的那个数据库,接着在右边“SQL”那里运行下面SQL语句。
本文将以著名博客老时说的博客地址改变作为例子,老时同志原来的博客地址http://www.shichangzhi.cn,然后现在老时想搞成http://www.shichangzhi.com,从国内的.cn域名换到了.com域名,当然换成.com域名之后老时会觉得更拉风了。
UPDATE wp_options SET option_value = replace( option_value, 'http://www.shichangzhi.cn', 'http://www.shichangzhi.com' ) WHERE option_name = 'home' OR option_name = 'siteurl';
UPDATE wp_posts SET post_content = replace( post_content, 'http://www.shichangzhi.cn', 'http://www.shichangzhi.com' ) ;
UPDATE wp_posts SET guid = replace( guid, 'http://www.shichangzhi.cn', 'http://www.shichangzhi.com' ) ;
为了不损失流量跟在搜索引擎中的收录,需要对原来的域名所在的主机进行301跳转。于是在老时http://www.shichangzhi.cn域名的安装wp的根目录对.htaccess进行修改。
RewriteEngine on
RewriteCond %{HTTP_HOST} !^www.shichangzhi.com$ [NC]
RewriteRule ^(.*)$ http://www.shichangzhi.com/$1 [L,R=301]
这样子以后访问.cn的所有地址都能够很好地跳转到.com的地址,而且对于流量来说几乎是不会有所损失。
博主很棒
Mark,终于找到这段SQL了,谢谢博主!
正如胡戈戈在hugege.com/2008/07/01/htaccess/中所言,顺序是个问题,因为有时候直接输入wordpress博客文章原地址依旧能访问,而不会发生跳转。解决办法是首先执行301跳转命令再执行其后的wordpress系统命令。如wp在根目录,即在RewriteBase /的下一行添加跳转语句,原有的系统命令不动内容,只是回车下移。
有部分服务器不支持,其实大部分都支持的