当前位置:首页 > 技术教程 > 正文

借助三条跳转规则,实现真正的301网站换域名重定向

事情起因:.com域名价格不断上涨,所以打算把非凡博客的域名更换为.cn域名,前两天已经完成新域名的备案了,为了确保将旧域名的权重传递到新域名,借助腾讯云的显性URL设置了301跳转,关于这种跳转的设置方法可以参考《设置域名A重定向301跳转到域名B不生效?有一个细节你可能忽略了》。
不过这样直接通过域名解析实现301重定向有一个问题,那就是跳转前的域名不支持HTTPS,以我自己的网站为例,也就意味着这种方法实现的效果是:
借助三条跳转规则,实现真正的301网站换域名重定向  第1张
如果仅仅是将HTTP的旧域名跳转到新域名,那么在百度站长工具设置网站改版的时候,也必须将旧域名退出HTTPS,否则规则会校验不成功。
借助三条跳转规则,实现真正的301网站换域名重定向  第2张
借助三条跳转规则,实现真正的301网站换域名重定向  第3张
但我还是希望能够找到一种可以实现完整重定向的方法,于是开始尝试修改服务器端重定向的规则文件,最终找到了两种方法可以实现HTTP和HTTPS两种协议头旧域名都能跳转到新域名的效果。
解决方案一:
我的服务器端使用的是LNMP环境,以下列出的跳转规则也仅适用于nginx。
1.旧域名和对应的网站目录、网站文件、网站数据库均保持不动,也就是保持旧网站可以正常访问。
2.将新域名解析至网站服务器,同时在服务器中添加新的网站目录环境,将旧域名的所有网站文件全部复制到新网站目录中,对应的数据库文件也导出,然后再导入到新网站的对应数据库中,也就相当于把旧网站完全复制了一份,实现的效果是新域名可以访问复制的网站。
3.找到nginx的配置文件,默认是在/usr/local/nginx/conf/vhost/旧域名.conf
借助三条跳转规则,实现真正的301网站换域名重定向  第4张
4.通过vi或vim编辑器访问旧域名的配置文件,如果已经安装了SSL证书,这里应该已经自动添加了以下规则:
server
     {
listen 80;
listen 443 ssl;
     }
我们要做的是在server下的括号中添加跳转规则:
if ( $scheme = "http" ) {
return 301 https://yudufeifan.cn$request_uri;
}
#http协议头的旧域名跳转到https新域名
if ( $scheme = "https" ) {
return 301 https://yudufeifan.cn$request_uri;
}
#https协议头的旧域名跳转到https新域名
location / {
rewrite ^(.*)$ https://yudufeifan.cn$1 permanent;
}
#旧域名的内页全部跳转到https新域名对应内页
注意把上面规则中的域名更换为自己的新域名。
借助三条跳转规则,实现真正的301网站换域名重定向  第5张
解决方案二:
方案一是通过协议头识别要跳转的旧域名,方案二可以通过具体的域名进行识别,可以采用以下规则:
if ( $host = "feifanblog.com" ) {
return 301 https://yudufeifan.cn$request_uri;
}
#不论协议头是http还是https,域名feifanblog.com都会跳转到新域名
if ( $host = "www.feifanblog.com" ) {
return 301 https://yudufeifan.cn$request_uri;
}
#不论协议头是http还是https,域名www.feifanblog.com都会跳转到新域名
location / {
rewrite ^(.*)$ https://yudufeifan.cn$1 permanent;
}
#旧域名的内页全部跳转到https新域名对应内页
注意把上面规则中的域名更换为自己的新域名。
以上两种方案任选一种即可,最终实现的效果可以参考当前非凡博客的域名重定向效果。