不少浏览器都开始逐渐更新至只支援 https 的网站,所以很多 http 网站都需要新增对 https 的支援,这时就需要涉及到 www 和不加 www 的跳转问题,由于 www 和不加 www 使用的是不同的证书,所以需要做 301 跳转处理,方案如下:
此处以域名 www.domain.com 和 testhttps.com 为例,修改 Nginx 配置档案中 www.domain.com 对应的配置档案:
server {
listen 80;
server_name domain.com www.domain.com;
return 301 https://www.domain.comm$request_uri;
}
server {
listen 443 ssl;
ssl_certificate /domain.com/cert.pem;
ssl_certificate_key /domain.com/privkey.pem;
server_name domain.com;
return 301 https://www.domain.com$request_uri;
}
server {
listen 443 ssl;
ssl_certificate /www.domain.com/cert.pem;
ssl_certificate_key /www.domain.com/privkey.pem;
server_name www.domain.com;
}
作用说明:
第一段程式码是将 http://www.domain.com 和 http://domain.com 301 重定向 https://www.domain.com;
第二段程式码是将 https://domain.com 301 重定向 https://www.domain.com;
第三段程式码是指定 https://www.domain.com 是 ssl 连线。
需要注意的是,第二段和第三段中的证书都需要各自域名对应的证书,比如说第二段就需要域名 https://domain.com 对应的证书,第三段就需要 https://www.domain.com 对应的证书。
按照上述示例修改为适合自己网站域名的设定,就可以实现在 https 模式下不加 www 强制跳转到 www 的功能。