场景:
在演练环境中,通过F5做负载均衡,前端项目获取的却是F5机器的ip。
日志截图:
分析:
从上图可以看到,X-Forwarded-For
是null,其他的也都是null,只有通过getRemoteAddr()
可以获取ip,但不是我们想要的;
那么问题就来了,X-Forwarded-For
为什么是null?
解决:
经与负责F5的技术人员沟通是其没有在F5中添加X-Forwarded-For
,导致它为null,之后添加上后,再获取时,就可以获取到客户端真实的ip了;
如图:
F5配置
F5中开启AutoMap,并传递X-Forwarded-For值
开启F5源地址转换"Auto Map"
https://images2015.cnblogs.com/blog/582266/201605/582266-20160517125509888-1957873778.png
方式一: 在http profile中开启X-Forwarded-For
方式二:在iRule中开启X-Forwarded-For
when HTTP_REQUEST {
HTTP::header insert "X-Forwarded-For" [IP::client_addr]
}
具体参考官方文档: 传送门
java项目获取
public String getIpAddress(HttpServletRequest request) {
// 获取请求主机IP地址,如果通过代理进来,则透过防火墙获取真实IP地址
String ip = request.getHeader("X-Forwarded-For");
String ipx = request.getHeader("x-forwarded-for");
logger.info("------ X-Forwarded-For ip:" + ip);
logger.info("------ x-forwarded-for ip:" + ipx);
if (ip != null && ip.length() != 0 && !"unknown".equalsIgnoreCase(ip)) {
// 多次反向代理后会有多个ip值,第一个ip才是真实ip
if (ip.indexOf(",") != -1) {
ip = ip.split(",")[0];
logger.info("------ 第一个 ip:" + ip);
}
}
if (ip == null || ip.length() == 0 || "unknown".equalsIgnoreCase(ip)) {
ip = request.getHeader("Proxy-Client-IP");
logger.info("------ Proxy-Client-IP ip:" + ip);
}
if (ip == null || ip.length() == 0 || "unknown".equalsIgnoreCase(ip)) {
ip = request.getHeader("WL-Proxy-Client-IP");
logger.info("------ WL-Proxy-Client-IP ip:" + ip);
}
if (ip == null || ip.length() == 0 || "unknown".equalsIgnoreCase(ip)) {
ip = request.getHeader("HTTP_CLIENT_IP");
logger.info("------ HTTP_CLIENT_IP ip:" + ip);
}
if (ip == null || ip.length() == 0 || "unknown".equalsIgnoreCase(ip)) {
ip = request.getHeader("HTTP_X_FORWARDED_FOR");
logger.info("------ HTTP_X_FORWARDED_FOR ip:" + ip);
}
if (ip == null || ip.length() == 0 || "unknown".equalsIgnoreCase(ip)) {
ip = request.getHeader("X-Real-IP");
logger.info("------ X-Real-IP ip:" + ip);
}
if (ip == null || ip.length() == 0 || "unknown".equalsIgnoreCase(ip)) {
ip = request.getRemoteAddr();
logger.info("------ getRemoteAddr ip:" + ip);
}
logger.info("客户端访问ip地址为:【" + ip + "】");
return ip;
}
author:su1573
鄙人记录生活点滴,学习并分享,请多指教!!!
如需交流,请联系 sph1573@163.com,鄙人看到会及时回复