美文网首页
更改https后,request.getScheme()只获取到

更改https后,request.getScheme()只获取到

作者: 你笑时很美丶 | 来源:发表于2020-03-19 10:04 被阅读0次

浏览器https://xxx.xxx.xxx,request.getScheme()获取到的地址是http而不是https

试了request.getRequestURL()拿到的也是http
因为我这里用的是nginx+tomcat转发https,tomcat接受到的请求都是来自于nginx的http请求。
request.getScheme() //http,而不是实际的https
request.isSecure() //false(因为是http)
request.getRemoteAddr() //nginx请求的 IP,而不是用户的IP
request.getRequestURL() //nginx请求的URL 而不是用户请求的 URL
response.sendRedirect( 相对url ) //重定向到 http 上 (因为认为当前是 http 请求)

解决办法
1. 在nginx 配置location处加上proxy_set_header X-Forwarded-Scheme $scheme; 通过request.getHeader("X-Forwarded-Scheme")获取真实的scheme
2. 在Tomcat server.xml中添加:
<Engine name="Catalina" defaultHost="localhost">
  这行之后

    <Valve className="org.apache.catalina.valves.RemoteIpValve"  remoteIpHeader="X-Forwarded-For" 
 protocolHeader="X-Forwarded-Proto" protocolHeaderHttpsValue="https"/>  

3.如果jsp中大量使用 request.getScheme() 获取,避免更改代码
    则需要配置 tomcat:

<Connector port="443" maxHttpHeaderSize="8192"
                 maxThreads="150"
                 enableLookups="false" disableUploadTimeout="true"
                 acceptCount="100" scheme="https" secure="true"
                 SSLEnabled="true"
                 SSLCertificateFile="${catalina.base}/conf/localhost.crt"
                 SSLCertificateKeyFile="${catalina.base}/conf/localhost.key" />

如果nginx添加了ssl认证,tomcat不添加,只配蓝色部分
  红色部分,如果tomcat 要添加ssl认证,配红色部分

相关文章

网友评论

      本文标题:更改https后,request.getScheme()只获取到

      本文链接:https://www.haomeiwen.com/subject/vcskyhtx.html