nginx tomcat SSL下的request获取信息问题

最近由于项目子系统比较多

所以拆分出了几个TOMCAT出来

但是客户方只给了一个端口号,非443

只能用代理的方式了刚好学习一下NGINX这个著名的WEB服务器

使用过程中,NGINX配了SSL后,在程序里的request.getServerPort取到的总是443,

网上没相关的修改默认端口的样例,只能自己查了


终于在http://tomcat.apache.org/tomcat-7.0-doc/api/org/apache/catalina/valves/RemoteIpValve.html

里找到了一个setPortHeader()的方法,

而TOMCAT7开始才有的,6.0里是没有这个方法的


详细方法如下:

NGINX配置以下:

location ~ /demo-* {
            root   html;
            index  index.html index.htm;
   proxy_pass   http://127.0.0.1:8080;
   proxy_set_header       Host $host;  
   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_set_header X-Forwarded-Port  $server_port;


        }

TOMCAT 需要在server.xml的


   <Valve   className="org.apache.catalina.valves.RemoteIpValve"
  remoteIpHeader="x-forwarded-for"
  remoteIpProxiesHeader="x-forwarded-by"
  protocolHeader="x-forwarded-proto"
  portHeader="x-forwarded-port"

  />


好了。这回正常了,未知坑继续探索

参与评论 您还未登录,请先 登录 后发表或查看评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
©️2022 CSDN 皮肤主题:大白 设计师:CSDN官方博客 返回首页

打赏作者

wingson_shen

你的鼓励将是我创作的最大动力

¥2 ¥4 ¥6 ¥10 ¥20
输入1-500的整数
余额支付 (余额:-- )
扫码支付
扫码支付:¥2
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、C币套餐、付费专栏及课程。

余额充值