文章目录
Spring boot项目中需要数据库中记录登陆者的IP,于是代码如下
public String getIpAddr(HttpServletRequest request) throws Exception {
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();
}
if (ip.equals("0:0:0:0:0:0:0:1")) {
ip = "本地";
// "0:0:0:0:0:0:0:1".equals(ip) ? "127.0.0.1" : ip;
}
return ip;
}
直接复制拿来用吧,类型不同
标题网络上常见的请求头
1、X-Forwarded-For
X-Forwarded-For 是一个 HTTP 扩展头部。
HTTP/1.1(RFC 2616) 协议并没有对它的定义,它最开始是由 Squid 这个缓存代理软件引入。如今它已经成为事实上的标准,被各大 HTTP 代理、负载均衡等转发服务广泛使用。只有在通过了 HTTP 代理或者负载均衡服务器时才会添加该项。
X-Forwarded-For 请求头格式非常简单:
-
X-Forwarded-For: client, proxy1, proxy2
一般情况下,第一个ip为客户端真实ip,后面的为经过的代理服务器ip。
2、Proxy-Client-IP
这个一般是经过apache http服务器的请求才会有,用apache http做代理时一般会加上Proxy-Client-IP请求头,而WL- Proxy-Client-IP是他的weblogic插件加上的请求头
3、WL- Proxy-Client-IP
weblogic插件加上的请求头
4、HTTP_CLIENT_IP
有些代理服务器会加上此请求头
5、X-Real-IP
nginx代理一般会加上此请求头
基础知识
访问服务器的方式一般分为两种:
- 未经过代理,直接访问服务器端;
- 通过多级代理,最终到达服务器端(Apache,Squid,nginx)
在JSP里,获取客户端的IP地址的方法是:request.getRemoteAddr(),这种方法在大部分情况下都是有效的。
经过了Apache,Squid,nginx等反向代理软件就不能获取到客户端的真实IP地址了,,由于在客户端和服务之间增加了中间层,因此服务器无法直接拿到客户端的IP,服务器端应用也无法直接通过转发请求的地址返回给客户端。但是在转发请求的HTTP头信息中,增加了X-Forwarded-For信息,可以X-Forwarded-For获取转发后请求信息,
当客户端访问经过转发,IP将会追加在其后并以逗号隔开。最终准确的客户端信息为:
- X-Forwarded-For 不为空,则为逗号前第一个IP;
- X-Real-IP 不为空,则为该IP;
- 否则为getRemoteAddress();
注意
0:0:0:0:0:0:0:1----ipv6地址
如果你拿到的IP是“0:0:0:0:0:0:0:1”,原因是客户端和服务器在同一台电脑上导致的,当我们用别的电脑访问本机时,如果无法打开,这个时候需要关闭自己电脑的防火墙
今天先写到这,再看懂百度了,我再在修改