• NGINX 下 由 http 强制跳转 https 的几种方法

    发布时间:2018-11-29 9:48 Thursday 作者:苏苏 阅读(359)


      现在越来越多的网站都开启了 https 访问了,一来安全,二来对搜索引擎也比较友好。三来嘛,肯定是市面上有大量的免费 SSL 证书,比如腾讯云、阿里云和景安都有提供免费的证书。在这里记录一下 http 强制跳转 https 的方法,为 138vps.com 日后开启 SSL 做个铺垫。

      首先要找到你网站的配置文件,如果使用的是军哥的 LNMP 脚本,路径在 /usr/local/nginx/conf/vhost/,如果是自己手动安装的nginx,Centos 7 配置文件一般在 /etc/nginx/conf.d/,具体哪个文件,就看你自己当时的配置了。

      我们要先配置好一个监听 443 端口的 server,然后就可以在监听 80 端口的 server 做以下的修改了。

      正常来说,这个 server 是这样的

      listen       80;

      server_name  www.138vps.com;

      .......


      我们直接在这两行的下面添加

      方法一 (这是最古老的写法,不推荐)

      rewrite ^(.*)$  https://$host$1 permanent; 


      方法二  (比较推荐)

      return     301 https://$server_name$request_uri; 


      方法三 如果你有多个域名绑定在一起,可以只设定某些域名强制跳转

      if ($host = "1.138vps.com") {

             rewrite ^/(.*)$ https://1.138vps.com permanent;

          }


      方法四

      方法四跟之前的都不一样,我们不需要另外监听 443 端口的 server,而是都放在一起,像这样

      listen 80;

      listen 443 ssl http2;

      server_name 138vps.com www.138vps.com;

      if ($server_port !~ 443){

          rewrite ^(/.*)$ https://$host$1 permanent;

      }


    特别申明:若无说明,文章均为原创,转载时请注明本文地址,谢谢合作!
    本文链接: