一、采纳 nginx 的 rewrite 办法
- 上面是将所有的 http 申请通过 rewrite 重写到 https 上。
例如将所有的 dev.wangshibo.com 域名的 http 拜访强制跳转到 https。
上面配置均能够实现:
server { listen 80; server_name dev.wangshibo.com; index index.html index.php index.htm; access_log /usr/local/nginx/logs/8080-access.log main; error_log /usr/local/nginx/logs/8080-error.log; # 办法1 这是ngixn早前的写法,当初还能够应用 rewrite ^(.*)$ https://$host$1 permanent; # 办法2 这是nginx最新反对的写法 # return 301 https://$server_name$request_uri; # 办法3 这种形式实用于多域名的时候,即拜访wangshibo.com的http也会强制跳转到https://dev.wangshibo.com下面 # 例如 server_name dev.wangshibo.com wangshibo.com *.wangshibo.com; # if ($host ~* "^wangshibo.com$") { # rewrite ^/(.*)$ https://dev.wangshibo.com/ permanent; # } # 上面是最简略的一种配置 # if ($host = "dev.wangshibo.com") { # rewrite ^/(.*)$ http://dev.wangshibo.com permanent; # } location ~ / { root /var/www/html/8080; index index.html index.php index.htm; } }
下面的跳转配置rewrite ^(.*)$ https://$host$1 permanent;
也能够改为上面rewrite ^/(.*)$ http://dev.wangshibo.com/$1 permanent;
或者rewrite ^ http://dev.wangshibo.com$request_uri? permanent;
二、通过proxy_redirec形式
# re-write redirects to http as to https, example: /homeproxy_redirect http:// https://;
参考链接
- Nginx 之 https 配置 - 运维笔记 (http->https 强转)
- Nginx百科全书-nginx 这一篇就够了