在apache+Weblogic整合系統中,apache會對request對象進行再包裝,附加一些WLS要用的頭信息。這種情況下,直接用request.getRemoteAddr()是無法取到真正的客戶IP的。
apache會增加下列頭信息:
X-Forwarded-For=211.161.1.239
WL-Proxy-Client-IP=211.161.1.239
所取得客戶的IP需要這樣:
String ip=request.getHeader("X-Forwarded-For");
if(ip == null || ip.length() == 0) {
ip=request.getHeader("WL-Proxy-Client-IP");
}
if(ip == null || ip.length() == 0) {
ip=request.getRemoteAddr();
}
或者也可通過weblogic的設置直接能過request.getRemoteAddr();取得客戶的IP。
在weblogic console
domain->servers->servername->General ->Advanced Options ->
WebLogic Plug-In Enabled
Specifies whether this server uses the proprietary WL-Proxy-Client-IP header. (This is needed only when WebLogic plugins are configured.)
但是如果apache設置的是反向代理這樣就不行了,因爲apache不會向heaer寫入WL-Proxy-Client-IP的信息。只能通過第一種方法解決。