1 package com.utils; 2 3 import org.slf4j.Logger; 4 import org.slf4j.LoggerFactory; 5 6 import javax.servlet.http.HttpServletRequest; 7 import java.io.IOException; 8 9 /** 10 * 獲取請求主機IP地址,若是經過代理進來,則透過防火牆獲取真實IP地址; 11 * 12 */ 13 public final class NetworkUtil { 14 15 private static final Logger LOG = LoggerFactory.getLogger(NetworkUtil.class); 16 17 public final static String getIpAddress(HttpServletRequest request) 18 throws IOException { 19 20 String ip = request.getHeader("X-Forwarded-For"); 21 22 // LOG.info("getIpAddress(HttpServletRequest) - X-Forwarded-For - String ip= {}" ,ip); 23 24 if (ip == null || ip.length() == 0 || "unknown".equalsIgnoreCase(ip)) { 25 if (ip == null || ip.length() == 0 26 || "unknown".equalsIgnoreCase(ip)) { 27 ip = request.getHeader("Proxy-Client-IP"); 28 // LOG.info("getIpAddress(HttpServletRequest) - Proxy-Client-IP - String ip= {}" , ip); 29 } 30 if (ip == null || ip.length() == 0 31 || "unknown".equalsIgnoreCase(ip)) { 32 ip = request.getHeader("WL-Proxy-Client-IP"); 33 // LOG.info("getIpAddress(HttpServletRequest) - WL-Proxy-Client-IP - String ip= {}" , ip); 34 } 35 if (ip == null || ip.length() == 0 36 || "unknown".equalsIgnoreCase(ip)) { 37 ip = request.getHeader("HTTP_CLIENT_IP"); 38 // LOG.info("getIpAddress(HttpServletRequest) - HTTP_CLIENT_IP - String ip= {}" , ip); 39 } 40 if (ip == null || ip.length() == 0 41 || "unknown".equalsIgnoreCase(ip)) { 42 ip = request.getHeader("HTTP_X_FORWARDED_FOR"); 43 // LOG.info("getIpAddress(HttpServletRequest) - HTTP_X_FORWARDED_FOR - String ip= {}" , ip); 44 } 45 if (ip == null || ip.length() == 0 46 || "unknown".equalsIgnoreCase(ip)) { 47 ip = request.getRemoteAddr(); 48 // LOG.info("getIpAddress(HttpServletRequest) - getRemoteAddr - String ip= {}" , ip); 49 } 50 } else if (ip.length() > 15) { 51 String[] ips = ip.split(","); 52 for (int index = 0; index < ips.length; index++) { 53 String strIp = (String) ips[index]; 54 if (!("unknown".equalsIgnoreCase(strIp))) { 55 ip = strIp; 56 break; 57 } 58 } 59 } 60 return ip; 61 } 62 }