Nginx+tomcat 实现ip穿透

Nginx+tomcat 实现ip穿透

当http请求通过Nginx转发后web服务器获取的ip其实是Nginx的ip,而不是请求源头的ip.如何实现服务器能拿到且后台代码也能获取.

为什么会获取不到原有的ip???

因为nginx将请求的host给重定义了,就是说重定义的发送请求的位置,那么自然拿不到原有请求的ip地址,nginx会在默认的情况下重定义以下两个字段:

proxy_set_header Host       

$proxy_host;proxy_set_header Connection close;

但是nginx支持重新定义或添加字段,用来传递给代理服务器的请求头.该值可以包含文本,变量和他们的组合.

那么我们就可以将原有的请求头信息通过定义新字段传递过去了.以下就是解决的方法:

1:nginx配置

格式 : proxy_set_header 字段名 字段值;

 

在Nginx的config文件中对应需要ip穿透的服务配置里添加以下配置信息:

 proxy_set_header Host $host:$server_port;

 proxy_set_header X-Real-IP $remote_addr;

 proxy_set_header X-Real-PORT $remote_port;

 proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;

2:tomcat的log配置

Log的配置中将pattern设置成:

%{X-Real-IP}i %l %u %t "%r" %s %b"

 

3:后台代码获取(java)

Java中使用request来获取header中的对应的字段的值即可:

request.getHeader("X-Real-IP")

 

 

 

转载于:https://my.oschina.net/wxdl/blog/864793

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值