【Nginx】设置https和http同时使用同一个端口访问,并且访问http跳转到https
当前位置:点晴教程→知识管理交流
→『 技术文档交流 』
突然有一个业务场景,同时使用 HTTP 和 HTTPS, 例如http和https都是9999端口,访问http://www.website.cn:9999,跳转到https://www.website.cn:9999,从http跳转到https。 其实就是利用 497代码进行跳转。
error_page 497 https://$host$request_uri;
server { listen 9999 ssl; server_name www.website.cn; ssl_certificate /www/server/panel/vhost/cert/www.website.cn/fullchain.pem; ssl_certificate_key /www/server/panel/vhost/cert/www.website.cn/privkey.pem; 剩下代码,左下角阅读原文获取。 通过使用 Nginx,可以实现同一端口同时支持 HTTP 和 HTTPS 协议。下面是一种可能的配置方式: 配置 HTTP 服务 在 Nginx 配置文件中,添加以下配置块用于处理 HTTP 请求: server { listen 80; # 监听 HTTP 请求,默认端口为 80 # 配置域名或 IP 地址 server_name example.com; # 处理 HTTP 请求的逻辑 location / { # 配置反向代理或其他操作 proxy_pass http://localhost:8000/; # 将请求转发至本地的某个服务 } } 配置 HTTPS 服务 在 Nginx 配置文件中,添加以下配置块用于处理 HTTPS 请求: server { listen 443 ssl http2; # 监听 HTTPS 请求,默认端口为 443 # 配置域名或 IP 地址 server_name example.com; # 配置 SSL/TLS 证书和密钥 ssl_certificate /path/to/certificate.crt; ssl_certificate_key /path/to/private.key; # 处理 HTTPS 请求的逻辑 location / { # 配置反向代理或其他操作 proxy_pass http://localhost:8000/; # 将请求转发至本地的某个服务 } } 启动Nginx 保存上述配置,并启动或重启Nginx服务,使配置生效。 以上配置假设将 HTTP 和 HTTPS 请求都转发至本地的某个服务(如运行在本地 8000 端口上的应用程序)。你需要相应地修改 proxy_pass 指令,将请求转发至实际的后端服务。同时,根据自己的证书和密钥路径来配置 SSL/TLS 部分。 通过上述配置,Nginx 将同时监听 HTTP 和 HTTPS 请求,并根据请求的协议类型进行适配转发。HTTP 请求会被转发至 80 端口,HTTPS 请求会被转发至 443 端口,而后端服务可以使用相同的端口(例如 8000)来处理这些转发的请求。 请注意,两个协议不能同时在一个端口上使用,上述利用http请求https端口时的错误码497将请求重定向到https,最终请求的还是https,so 两个协议不能同时在一个端口上使用。 为了支持 HTTPS,必须配置正确的 SSL/TLS 证书和密钥,并确保与所使用的域名匹配。此外,HTTP2 是一种可选配置,用于提供性能优化的协议版本。 阅读原文:原文链接 该文章在 2025/12/10 18:49:32 编辑过 |
关键字查询
相关文章
正在查询... |