解决nginx非标准https端口被强制跳转到默认443端口的问题[转]
首页 > IT > Unix/Linux   作者:eehello  2023年1月7日 23:38 星期六  浏览:326  字号:   评论:0 条
时间:2023-1-7 23:38   浏览:326  评论:0 条 

转自:http://t.zoukankan.com/jonnyan-p-12966280.html


如果正常的,80 端口 HTTP 跳转 HTTPS,那么直接在 server listen 80 下写

return 301 https://$host$request_uri;

就行

但是,现在的情况是,80/443 都有服务了,然后在 8088 端口上开了一个需要客户端证书认证的 TLS 双向认证服务,通过 https://www.jonnyan404.top:8088 可以成功访问,浏览器会提示选择客户端证书,这都没问题。

但是在首次访问的时候,如果没有显式指定 https 协议,将会自动默认使用 http 协议来访问 443 端口,导致 nginx 报错:400 Bad Request: The plain HTTP request was sent to HTTPS port。

正确配置如下:

497状态码是专门为解决非标准ssl端口跳转问题.


server {
listen 8443 ssl http2;
server_name xxxxx.com;

error_page 497 301 =307 https://$host:$server_port$request_uri;

ssl_verify_client on;



 您阅读这篇文章共花了: 
二维码加载中...
本文作者:eehello      文章标题: 解决nginx非标准https端口被强制跳转到默认443端口的问题[转]
本文地址:https://www.eehello.com/?post=322
版权声明:若无注明,本文皆为“点滴记忆---观雨亭”原创,转载请保留文章出处。

返回顶部| 首页| 手气不错| 留言板|后花园

Copyright © 2014-2023 点滴记忆---观雨亭