前言
虽然使用加密连接https
更加安全,但在一些特定情况下却只能使用http
不能使用加密连接;
在宝塔面板中开启SSL
强制跳转后全站所有目录都会跳转到https
并没有例外的选项;
本来以为加一条if
指定条件不跳转就行了,结果不能实现,原来Nginx
不支持if
逻辑和嵌套语法;
最后找了不少资料,终于可以实现开启强制跳转后指定目录不跳转https
的方案了;
方案
宝塔面板开启强制跳转https
后Nginx
的配置文件是如下代码;
if ($server_port !~ 443){
rewrite ^(/.*)$ https://$host$1 permanent;
}
然后我们在网站-设置-配置文
件中用以下代码替换掉上面的代码即可;
set $flag 0;
if ($server_port !~ 443) {
set $flag "${flag}1";
}
if ($request_uri !~ "/AAA"){
set $flag "${flag}2";
}
if ($flag = "012"){
rewrite ^(.*)$ https://$host$1 permanent;
}
条件解释:满足非443
端口并且域名目录非/AAA
时跳转,包含/AAA
目录不跳转;
说明
我们指定不跳转的目录是/AAA
但如果有同名目录,比如/AAAA
或/AAABB
同样也不会跳转;
测试
跳转:http://sunpma.com
不跳转:http://sunpma.com/other/ariang
相关推荐: Windows Server开启IPv6 Forwarding实现Hyper-V虚拟机分配IPv6公网地址
文章目录[隐藏] 前言 开始配置 前言 查询了很多文档,但是这方面的信息非常的有限,经过各种折腾和实践终于搞定了。这里分享出来给大家看看,也作为笔记以供后面自查。 开始配置 准备工作 1. 网卡硬件配置: – 内网物理网卡 * 1 – 公网物理网卡 * 1 –…
© 版权声明
文章版权归作者所有,未经允许请勿转载。
THE END
喜欢就支持一下吧
相关推荐
评论 抢沙发
请登录后发表评论
注册