前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >宝塔面板使用问题记录【强制HTTPS】后网站无法访问

宝塔面板使用问题记录【强制HTTPS】后网站无法访问

作者头像
铭心
发布于 2025-01-14 01:28:31
发布于 2025-01-14 01:28:31
51700
代码可运行
举报
文章被收录于专栏:铭心の博客铭心の博客
运行总次数:0
代码可运行

问题背景

家庭宽带申请的公网 IP,80 和 443 端口被封锁,无法直接通过公网访问。希望如果 443 端口可访问,则优先使用。如果 443 端口不可访问,则使用 8443 端口。

配置环境:
  • 基于宝塔面板搭建,使用 nginx。
  • 监听端口:443(SSL)和 8443(SSL)。
  • 启用了 强制 HTTPS,内网 HTTP 请求自动跳转到 HTTPS。
问题:
  • 开启强制HTTPS导致非443 端口(如 8443)访问时强制跳转到 443,公网无法使用 8443 提供的 HTTPS 服务。

现象对比

原始规则【宝塔自带】
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
# HTTP_TO_HTTPS_START
if ($server_port !~ 443) {
    rewrite ^(/.*)$ https://$host$1 permanent;
}
# HTTP_TO_HTTPS_END

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
# HTTP_TO_HTTPS_START
set $isRedcert 1;
if ($server_port != 443) {
    set $isRedcert 2;
}
if ($uri ~ /\.well-known/) {
    set $isRedcert 1;
}
if ($isRedcert != 1) {
    rewrite ^(/.*)$ https://$host$1 permanent;
}
# HTTP_TO_HTTPS_END
  • 逻辑:请求端口不是443时,会强制跳转至443。
新规则【更改后】
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
# HTTP_TO_HTTPS_START
# 增加8443端口豁免
if ($server_port !~ (443|8443)) {
    rewrite ^(/.*)$ https://$host$1 permanent;
}
# HTTP_TO_HTTPS_END

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
# HTTP_TO_HTTPS_START
set $isRedcert 1;
# 增加8443端口豁免
if ($server_port != (443|8443)) {
    set $isRedcert 2;
}
if ($uri ~ /\.well-known/) {
    set $isRedcert 1;
}
if ($isRedcert != 1) {
    rewrite ^(/.*)$ https://$host$1 permanent;
}
# HTTP_TO_HTTPS_END
  • 逻辑:请求端口不是443或8443时,会强制跳转至443。
  • 优点:增加端口豁免,443和8443端口不会强制跳转,保持了对多端口的支持。

解决方案

临时方法
  • 说明:新增了对 8443 的支持,避免 8443 被强制跳转。
  • 手动更改网站的 nginx 配置文件:
  1. 找到 nginx 配置文件路径(宝塔面板中:网站管理 -> 设置 -> 配置文件)。
  2. 根据对应原始规则更改为上面提到的新规则,此方法在重新部署证书或重新打开【强制HTTPS】后会被覆盖配置。
永久方法
  • 修改宝塔面板的内置规则,虽然部署证书和强制HTTPS不会覆盖配置,但是面板更新后会对更改的.py进行覆盖,尽量避免更新。
  • 备份以下文件,避免修改出错:
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
cp /www/server/panel/mod/project/docker/sites/sslManage.py
/www/server/panel/mod/project/docker/sites/sslManage.py.bak
cp /www/server/panel/mod/project/docker/sites/base.py /www/server/panel/mod/project/docker/sites/base.py.bak
cp /www/server/panel/mod/project/proxy/comMod.py /www/server/panel/mod/project/proxy/comMod.py.bak
  • 修改 sslManage.py 文件
  • 路径:/www/server/panel/mod/project/docker/sites/sslManage.py,找到 525:527 行,修改规则为:
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
if ($server_port != (443|8443)) { set $isRedcert 2; }
  • 修改 base.py 文件
  • 路径:/www/server/panel/mod/project/docker/sites/base.py找到 158 行,修改规则为:
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
"force_conf": "    #HTTP_TO_HTTPS_START\n    set $isRedcert 1;\n    if ($server_port != (443|8443)) {\n        set $isRedcert 2;\n    }\n    if ( $uri ~ /\.well-known/ ) {\n        set $isRedcert 1;\n    }\n    if ($isRedcert != 1) {\n        rewrite ^(/.*)$ https://$host$1 permanent;\n    }\n    #HTTP_TO_HTTPS_END",
  • 修改 comMod.py 文件
  • 路径:/www/server/panel/mod/project/proxy/comMod.py,找到 54 行,修改规则为:
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
"force_conf": "    #HTTP_TO_HTTPS_START\n    set $isRedcert 1;\n    if ($server_port != (443|8443)) {\n        set $isRedcert 2;\n    }\n    if ( $uri ~ /\.well-known/ ) {\n        set $isRedcert 1;\n    }\n    if ($isRedcert != 1) {\n        rewrite ^(/.*)$ https://$host$1 permanent;\n    }\n    #HTTP_TO_HTTPS_END",
  • 重启宝塔服务
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
bt restart
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2025-01-13,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 问题背景
    • 配置环境:
    • 问题:
  • 现象对比
    • 原始规则【宝塔自带】
    • 新规则【更改后】
  • 解决方案
    • 临时方法
    • 永久方法
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档