LNMP下HTTP强制跳转HTTPS的几种写法

cera cera

现在越来越多的网站都启用https访问了,SSL证书也不贵,还有一些免费的比如Let’s Encrypt或者腾讯也有提供1年免费证书等等,加上https有更好的安全性,甚至有人说以后搜索引擎都更青睐https的网站…今天就记录下在HTTP强制跳转HTTPS的几种方式方法,方便哪天我要加SSL的时候使用。

我们需要修改域名配置文件,这里我以军哥LNMP环境为例,路径在/usr/local/nginx/conf/vhost/


如上图,选择部分就是添加的跳转内容,通常我们有多种写法方式,下面列举。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
No.1
if ($scheme = http ) {
return 301 https://$host$request_uri; }
 
No.2
server_name zrblog.net ;
rewrite ^(.*) https://www.zrblog.net$1 permanent;
 
No.3
if ($server_port = 80 ) {
return 301 https://$host$request_uri; }
 
No.4
server_name zrblog.net ;
return 301 https://$server_name$request_uri;
延伸:如果网站不是采用的NGINX而是APACHE,那就更加简单了,直接在网站根目录修改.htaccess文件,加入:

1
2
3
4
5
RewriteEngine On
RewriteCond %{HTTP_HOST} !^www.zrblog.net$ [NC]
RewriteRule ^(.*)$ https://www.zrblog.net/$1 [L,R=301]
RewriteCond %{SERVER_PORT} 80
RewriteRule ^(.*)$ https://www.zrblog.net/$1 [L,R=301]

这样的话,除了不加www的域名访问,也会自动跳转到www域名并HTTPS访问。

NGINX的其他写法方式:

1
2
3
4
5
6
7
8
rewrite ^(.*)$? https://$host$1 permanent;  #1
return 301 https://$server_name$request_uri; #2
if ($host ~* "^zrblog.net$") {
rewrite ^/(.*)$ https://www.zrblog.net/ permanent;
}     #3
if ($host = www.zrblog.net) {
rewrite ^/(.*)$ http://www.zrblog.net permanent;
}    #4

以上搜集自网络,如有错漏,请大家帮忙指正!谢谢。

cera cloudiplc tengxunyun

相关推荐