request.getRemoteAddr()取不到真实ip的解决办法

简介:

request.getRemoteAddr()取不到真实ip的解决办法

我们一般在服务器取客户端ip. 都是用:request.getRemoteAddr()代码就可以了

但是, 也有例外的时候。最近出现了一个问题。 就是request.getRemoteAddr() 取不到真实ip了。。

request.getRemoteAddr()这种方法在大部分情况下都是有效的。

但是在通过了Apache,Squid等反向代理软件就不能获取到客户端的真实IP地址了。

  如果使用了反向代理软件,将http://192.168.1.101:8080/ 的URL反向代理为http://www.xxx.com/ 的URL时,用request.getRemoteAddr()方法获取的IP地址是:127.0.0.1 或 192.168.1.101,而并不是客户端的真实ip。

七七八八网http://www.qi788.com

经过代理以后,由于在客户端和服务之间增加了中间层,因此服务器无法直接拿到客户端的IP,服务器端应用也无法直接通过转发请求的地址返回给客户端。但是在转发请求的HTTP头信息中,增加了X-FORWARDED-FOR信息用以跟踪原有的客户端IP地址和原来客户端请求的服务器地址。

最后解决办法:

  1. public String getIpAddr(HttpServletRequest request) {      
  2.        String ip = request.getHeader("x-forwarded-for");      
  3.       if(ip ==null || ip.length() ==0 || "unknown".equalsIgnoreCase(ip)) {      
  4.           ip = request.getHeader("Proxy-Client-IP");      
  5.       }      
  6.       if(ip ==null || ip.length() ==0 || "unknown".equalsIgnoreCase(ip)) {      
  7.           ip = request.getHeader("WL-Proxy-Client-IP");      
  8.        }      
  9.      if(ip ==null || ip.length() ==0 || "unknown".equalsIgnoreCase(ip)) {      
  10.            ip = request.getRemoteAddr();      
  11.       }      
  12.      return ip;      

  通过了多级反向代理的话,X-Forwarded-For的值并不止一个,而是一串ip值,究竟哪个才是真正的用户端的真实IP呢?


  是取X-Forwarded-For中第一个非unknown的有效IP字符串。如:X-Forwarded-For:192.168.1.101, 192.168.1.120, 192.168.1.130, 192.168.1.100,用户真实IP为: 192.168.1.101

request.getRemoteAddr()取不到真实ip的解决办法


来源资料文章 记住这里http://www.qi788.com/info


      本文转自yjflinchong 51CTO博客,原文链接:http://blog.51cto.com/yjflinchong/1164933,如需转载请自行联系原作者





相关文章
|
SQL 安全 API
api接口是什么意思,api接口该如何防护呢?
api接口是什么意思,api接口该如何防护呢?
|
4月前
|
人工智能 监控 安全
2026年阿里云+本地部署OpenClaw终极进化指南:Agent-Reach skill一条命令实时读取B站、小红书等全平台内容
2026年,AI智能体的核心竞争力已从“模型大小”转向“视野广度”。OpenClaw(原Clawdbot、Moltbot)作为开源AI助手的标杆,虽能实现7×24小时自动化任务执行,但传统使用模式下仍受限于“信息孤岛”——需手动投喂内容、依赖付费API、实时信息获取能力薄弱。而刚爆火的开源工具Agent-Reach(900+ GitHub Star)彻底改变这一现状,它就像给OpenClaw装上“全网眼睛”,零API费、零配置,一条命令即可让AI实时读取Twitter、B站、小红书等全平台内容,真正实现“自主上网、主动感知”。
2696 2
|
NoSQL 前端开发 Redis
Windows 下安装和配置 Redis (图文教程)
Windows 下安装和配置 Redis (图文教程)
|
Java 数据安全/隐私保护 微服务
微服务——SpringBoot使用归纳——Spring Boot中使用监听器——Spring Boot中自定义事件监听
本文介绍了在Spring Boot中实现自定义事件监听的完整流程。首先通过继承`ApplicationEvent`创建自定义事件,例如包含用户数据的`MyEvent`。接着,实现`ApplicationListener`接口构建监听器,用于捕获并处理事件。最后,在服务层通过`ApplicationContext`发布事件,触发监听器执行相应逻辑。文章结合微服务场景,展示了如何在微服务A处理完逻辑后通知微服务B,具有很强的实战意义。
782 0
|
安全 API PHP
港澳台验证码海外短信群发教程,利用阿里云国际如何实现境外短信操作
港澳台验证码海外短信群发教程,利用阿里云国际如何实现境外短信操作
|
NoSQL MongoDB 索引
MongoDB 全文检索
10月更文挑战第23天
259 1
|
安全 API 网络安全
API接口安全加固:应对黑客攻击的实战指南
**API安全摘要:** API成为黑客目标,攻击类型包括未授权访问、CSRF、DDoS、数据泄露和注入攻击。防御策略包括使用OAuth 2.0和JWT进行认证授权,防止CSRF攻击,限制请求速率,避免数据泄露,以及实施注入攻击防护。开发者应定期更新安全措施,确保API安全性。示例代码展示了Node.js中JWT认证的实现。
725 0
|
虚拟化 iOS开发 MacOS
客户机操作系统已禁用 CPU。请关闭或重置虚拟机。解决方法
客户机操作系统已禁用 CPU。请关闭或重置虚拟机。解决方法
6961 0
|
缓存 应用服务中间件 nginx
Nginx 作为反向代理优化要点proxy_buffering
当nginx用于反向代理时,每个客户端将使用两个连接:一个用于响应客户端的请求,另一个用于到后端的访问; 那么,可以从如下配置起步: 1 2 3 4 5 6 7 8 9 10 11 12 13 14 # One worker per CPU-core.
10520 144

热门文章

最新文章