关注VPS主机与
服务器促销分享

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

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

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

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

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文件,加入:

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的其他写法方式:

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

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

赞(0)
版权声明:本文采用知识共享 署名4.0国际许可协议 [BY-NC-SA] 进行授权, 转载请注明出处。
文章名称:《LNMP下HTTP强制跳转HTTPS的几种方式方法》
文章链接:https://www.zyhot.com/article/580.html
关于安全:任何IDC都有倒闭和跑路的可能,月付和备份是您的最佳选择,请保持良好的、有规则的备份习惯。
本站声明:本站仅做信息分享,不参与任何交易,也非中介,仅记录个人感兴趣的主机测评结果和优惠活动,内容均不作直接、间接、法定、约定的保证。访问本站请务必遵守有关互联网的相关法律、规定与规则。一旦您访问本站,即表示您已经知晓并接受了此声明通告。

评论 抢沙发

评论前必须登录!

 

登录

找回密码

注册