nginx 同一个端口同时支持 http 和 https

707次阅读
没有评论

[root@VM-0-22-centos conf.d]# cat tx.qmgr.com.conf
upstream gatewayservice {server 127.0.0.1:8080 weight=1;}

server {

listen 27800 ssl;
server_name tx.qmgr.com; #业务系统域名
ssl_certificate /etc/nginx/cert/tx.qmgr.com.pem; #业务系统域名证书公钥
ssl_certificate_key /etc/nginx/cert/tx.qmgr.com.key; #业务系统域名证书私钥
ssl_protocols TLSv1 TLSv1.1 TLSv1.2 TLSv1.3;
ssl_ciphers HIGH:!aNULL:!MD5;

set $redirectMode gatewayservice;

location / {
proxy_set_header Host $host:$server_port;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Forwarded-Proto $scheme;

#判断是 https 请求,就直接跳转,然后断开这个连接不希望往下执行
if ($scheme = 'https') {
proxy_pass http://gatewayservice;
break;
}

#上面做了判断,所以现在是 http 访问,会跟下面 location 的 @http_to_https 进行关联
try_files $uri $uri/ @http_to_https;
index index.html index.htm;
}

location @http_to_https {
proxy_set_header Host $host:$server_port;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Forwarded-Proto $scheme;
proxy_pass http://gatewayservice;
}

error_page 497 = @http_to_https;
error_page 405 =200 $uri;
error_page 404 /404.html;
#由于上面配置了 ssl 证书,如果你 http 访问,就会出现 497 报错,这个时候就直接跳转到上面的 location 的 @http_to_https。相当于跳转 https 的请求。location = /40x.html {
}
error_page 500 502 503 504 /50x.html;
location = /50x.html {}}

# 测试 http 访问,
nginx 同一个端口同时支持 http 和 https
#测试 https 访问

nginx 同一个端口同时支持 http 和 https

# 测试成功,完美实现。

微信扫描下方的二维码阅读本文

正文完
 0
柹子丶
版权声明:本站原创文章,由 柹子丶 于2023-01-28发表,共计1254字。
转载说明:除特殊说明外本站文章皆由CC-4.0协议发布,转载请注明出处。
评论(没有评论)
验证码