[size=medium] 在JSP里,获取客户端的IP地址的方法是:request.getRemoteAddr(),这种方法在大部分情况下都是有效的。但是在通过了Apache,Squid,nginx等反向代理软件就不能获取到客户端的真实IP地址了。
如果使用了反向代理软件,将http://192.168.1.110:2046/ 的URL反向代理为 http://www.jb51.net / 的URL时,用request.getRemoteAddr()方法获取的IP地址是:127.0.0.1 或 192.168.1.110,而并不是客户端的真实IP。
经过代理以后,由于在客户端和服务之间增加了中间层,因此服务器无法直接拿到客户端的IP,服务器端应用也无法直接通过转发请求的地址返回给客户端。但是在转发请求的HTTP头信息中,增加了X-FORWARDED-FOR信息。用以跟踪原有的客户端IP地址和原来客户端请求的服务器地址。当我们访问http://www.jb51.net /index.jsp/ 时,其实并不是我们浏览器真正访问到了服务器上的index.jsp文件,而是先由代理服务器去访问http://192.168.1.110:2046/index.jsp ,代理服务器再将访问到的结果返回给我们的浏览器,因为是代理服务器去访问index.jsp的,所以index.jsp中通过request.getRemoteAddr()的方法获取的IP实际上是代理服务器的地址,并不是客户端的IP地址。
package com.rapido.utils;
import javax.servlet.http.HttpServletRequest;
/**
* 自定义访问对象工具类
*
* 获取对象的IP地址等信息
* @author X-rapido
*
*/
public class CusAccessObjectUtil {
/**
* 获取用户真实IP地址,不使用request.getRemoteAddr();的原因是有可能用户使用了代理软件方式避免真实IP地址,
*
* 可是,如果通过了多级反向代理的话,X-Forwarded-For的值并不止一个,而是一串IP值,究竟哪个才是真正的用户端的真实IP呢?
* 答案是取X-Forwarded-For中第一个非unknown的有效IP字符串。
*
* 如:X-Forwarded-For:192.168.1.110, 192.168.1.120, 192.168.1.130,
* 192.168.1.100
*
* 用户真实IP为: 192.168.1.110
*
* @param request
* @return
*/
public static String getIpAddress(HttpServletRequest request) {
String ip = request.getHeader("x-forwarded-for");
if (ip == null || ip.length() == 0 || "unknown".equalsIgnoreCase(ip)) {
ip = request.getHeader("Proxy-Client-IP");
}
if (ip == null || ip.length() == 0 || "unknown".equalsIgnoreCase(ip)) {
ip = request.getHeader("WL-Proxy-Client-IP");
}
if (ip == null || ip.length() == 0 || "unknown".equalsIgnoreCase(ip)) {
ip = request.getHeader("HTTP_CLIENT_IP");
}
if (ip == null || ip.length() == 0 || "unknown".equalsIgnoreCase(ip)) {
ip = request.getHeader("HTTP_X_FORWARDED_FOR");
}
if (ip == null || ip.length() == 0 || "unknown".equalsIgnoreCase(ip)) {
ip = request.getRemoteAddr();
}
return ip;
}
}
[/size]
该博文引自:
http://www.jb51.net/article/67050.htm
分享到:
相关推荐
主要介绍了Java中使用HttpRequest获取用户真实IP地址,使用本文方法可以避免Apache、Squid、nginx等反向代理软件导致的非真实IP地址,需要的朋友可以参考下
在Asp.net开发中,获取访问用户IP地址和IP归属地是常见的需求,这有助于我们进行用户定位、数据分析以及安全防护等工作。纯真IP数据库(QQWry.Dat)是广泛使用的IP地址库,它提供了丰富的IP地址到地理位置的映射信息...
java获取IP地址和MAC地址。 /** * 通过HttpServletRequest返回IP地址 * @param request HttpServletRequest * @return ip String * @throws Exception */ public String getIpAddr(HttpServletRequest ...
2. **性能考虑**:尽管使用`Dns.GetHostEntry()`来获取IP地址非常方便,但在频繁调用的情况下可能会影响性能。可以考虑将获取到的IP地址缓存起来,减少不必要的查询次数。 3. **多网卡支持**:现代计算机可能配备有...
在Java中,可以使用`java.net.HttpURLConnection`类来实现这一功能。`HttpRequest`类中的`getData`方法就是一个简单的HTTP GET请求示例,它创建了一个`URL`对象,然后通过`openConnection()`方法打开与该URL的连接,...
HttpRequest.java程序源码下载
在ASP.NET中,获取客户端的IP地址是常见的需求,特别是在进行数据分析、用户定位或安全控制时。使用C#编程语言可以方便地实现这一功能。在VS2005环境下,我们可以利用内置的HttpRequest对象来获取客户端的IP地址。...
本篇文章将详细讲解如何在Java中获取HttpRequest Header的各种方法,这对于理解Web应用的交互机制以及优化用户体验至关重要。 首先,我们需要引入javax.servlet.http.HttpServletRequest接口,它是Servlet API的一...
在.NET开发环境中,获取客户端的IP地址和MAC地址是常见的需求,这主要涉及到网络通信和系统编程的相关知识。本文将详细讲解如何在.NET中实现这一功能,并提供相关的代码示例。 首先,我们要明白IP地址和MAC地址的...
通过JavaServlet读取HttpRequest中的XML文件内容
在C# .NET编程环境中,获取用户访问者的IP地址并进一步确定其所在地区是一项常见的需求,这在构建网站、分析用户行为或者实现地理定位服务时非常有用。本教程将指导初学者如何通过C# .NET实现这一功能,利用QQ纯真IP...
在C#编程环境中,获取IP地址是一项常见的任务,特别是在网络通信和服务器开发中。本文将深入探讨如何在C#中获取本地或远程主机的IP地址,并提供相关代码示例。 首先,我们需要理解IP地址的基本概念。IP地址...
在ASP.NET开发中,有时我们需要获取服务器或者客户端的IP地址和MAC地址来进行特定的功能实现,例如用户定位、网络管理或安全验证。以下是对这个主题的详细讲解。 首先,我们要了解IP地址和MAC地址的基本概念。IP...
提供的代码文件"获取本机IP地址和网关地址+获取注册用户的IP地址.cs"应该包含了上述所有功能的实现,可以作为开发过程中获取IP地址的参考。理解并运用这些方法,开发者可以有效地管理和跟踪网络通信,为各种网络应用...
在Java Web开发中,通过`HttpServletRequest`对象可以获取客户端请求的各种信息,包括但不限于路径信息。这些路径信息对于开发者来说至关重要,尤其是在处理文件上传下载、资源定位等场景下。本文将详细介绍如何通过...
java读取接口代码,形如:http://127.0.0.1:8088/hlapp/train/validationCardInfo?a=X&b=X 这样的接口可以用该方法。
标题中的"HttpRequest.java-master.rar"表明这是一个关于Java编程的项目,主要涉及HttpRequest类,可能是一个...通过阅读和分析HttpRequest类的源代码,开发者可以学习到如何在Java中实现高效、灵活的HTTP客户端功能。
在本文中,我们将深入探讨如何使用C#编程语言在Visual Studio 2005(VS2005)环境中获取客户端IP地址,并将其与IP标准库进行比对。这是一个非常实用的技术,尤其对于开发需要验证用户IP地址的应用程序或者需要记录...
在本文中,我们将深入探讨HttpRequest的工作原理、主要功能以及如何在实际应用中使用它,特别是通过ASIHttpRequst这个库来实现HTTP请求。 一、HttpRequest基本概念 HttpRequest是HTTP协议的一部分,它是客户端(如...