浏览器输入https://www.mysite.com,后台经过request.getScheme()获取到的确实http而不是https,经过request.getRequestURL()拿到的也是http://www.mysite.comnginx
分析缘由:由于nginx+tomcat部署web服务,tomcat接受到的请求都是来自于nginx的http请求。浏览器请求https是外网域名或者ip,在浏览器发出请求时通过nginx代理拦截会进行证书验证,验证经过后nginx把外网请求转发到内网服务器,通常都是http请求,由于https证书只针对外网ip,内网服务没法配置ssl证书,并且若是转发到web服务器也是https请求,那么每一个web服务都须要配置ssl证书。web
方案一:修改服务端,支持https请求,nginx的配置改成proxy_pass https://xrk_biz_web2_8013;spring
方案二:在nginx端强制重定向http到https。浏览器
方案三:修改服务端逻辑代码(配置文件中主机访问地址及redirect补全主机地址),保证相关回调连接都是https开头。tomcat
方案四:使用spring-boot官方提供的解决方案,nginx添加配置(最终采用):服务器
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Forwarded-Proto https;spring-boot