https通过ngxin在web服务器收到http请求

一. 问题描述:

nginx代理nexus的时候页面不全,部分https地址自动转成http了,使用方案四解决的

      浏览器输入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

相关文章
相关标签/搜索