使用nginx反向代理后如何在后台web应用中获取用户ip

在使用nginx作为反向代理时,通过request.getRemoteAddr()获取的IP是nginx服务器的地址,而非用户真实IP。解决办法是在nginx配置中设置`proxy_set_header X-Real_IP $remote_addr;`,将用户真实IP保存到X-Real_IP头中,然后在web应用中读取该头来获取用户IP。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

问题背景

在实际应用中,我们可能需要获取用户的ip地址,比如做异地登陆的判断,或者统计ip访问次数等,通常情况下我们使用

request.getRemoteAddr()

就可以获取到客户端ip,但是当我们使用了nginx作为反向代理后,使用request.getRemoteAddr()获取到的就一直是nginx服务器的ip的地址,那这时应该怎么办?

原理解释

经过反向代理后,由于在客户端和web服务器之间增加了中间层,因此web服务器无法直接拿到客户端的ip,通过$remote_addr变量拿到的将是反向代理服务器的ip地址。

当你使用了nginx反向服务器后,在web端使用request.getRemoteAddr()本质上就是获取$remote_addr),取得的是nginx的地址,即$remote_addr变量中封装的是nginx的地址,当然是没法获得用户的真实ip的,但是,nginx是可以获得用户的真实ip的,也就是说nginx使用$remote_addr变量时获得的是用户的真实ip,如果我们想要在web端获得用户的真实ip,就必须在nginx这里作一个赋值操作,如下:
proxy_set_header  X-Real_IP  $remote_addr;
其中这个X-Real_IP是一个自定义的变量名,名字可以随意取,这样做完之后,用户的真实ip就被放在X-Real_IP这个变量里了,然后,在web端可以这样获取:

request.getHeader("X-Real_IP");

通常我们会看到有这样一些配置

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

非ban必选

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

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

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

打赏作者

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

抵扣说明:

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

余额充值