今天遇到一个问题,我通过浏览器输入https://www.mysite.com,后台通过request.getScheme()获取到的确实http而不是https
通过request.getRequestURL()拿到的也是http://www.mysite.com
分析原因,是因为用nginx+tomcat部署web服务,tomcat接受到的请求都是来自于nginx的http请求。
解决办法:在nginx 配置location处加上proxy_set_header X-Forwarded-Scheme $scheme;
后台通过request.getHeader("X-Forwarded-Scheme")获取真实的scheme
本文介绍了一个关于Nginx与Tomcat部署中HTTPS请求被误识别为HTTP的问题及解决方案。通过调整Nginx配置文件,在location部分增加proxy_set_header X-Forwarded-Scheme $scheme指令,使Tomcat能够正确识别并处理HTTPS请求。
1165

被折叠的 条评论
为什么被折叠?



