JSP 獲取用戶的真實(shí)IP兩種實(shí)現(xiàn)方法詳解
JSP 獲取用戶的真實(shí)IP兩種實(shí)現(xiàn)方法詳解
在JSP里,獲取客戶端的IP地址的方法是:request.getRemoteAddr(),這種方法在大部分情況下都是有效的。但是在通過了 Apache,Nagix等反向代理軟件就不能獲取到客戶端的真實(shí)IP地址了。如果使用了反向代理軟件,用 request.getRemoteAddr()方法獲取的IP地址是:127.0.0.1或 192.168.1.110,而并不是客戶端的真實(shí)IP。
經(jīng)過代理以后,由于在客戶端和服務(wù)之間增加了中間層,因此服務(wù)器無法直接拿到客戶端的 IP,服務(wù)器端應(yīng)用也無法直接通過轉(zhuǎn)發(fā)請求的地址返回給客戶端。但是在轉(zhuǎn)發(fā)請求的HTTP頭信息中,增加了X-FORWARDED-FOR信息。用以跟蹤原有的客戶端 IP地址和原來客戶端請求的服務(wù)器地址。
舉例來說,當(dāng)我們訪問口碑網(wǎng)首頁hangzhou.jsp時(shí),其實(shí)并不是我們?yōu)g覽器真正訪問到了服務(wù)器上的hangzhou.jsp 文件,而是先由代理服務(wù)器Nagix去訪問hagnzhou.jsp ,代理服務(wù)器再將訪問到的結(jié)果返回給我們的瀏覽器,因?yàn)槭谴矸?wù)器去訪問hangzhou.jsp的,所以hangzhou.jsp中通過 request.getRemoteAddr()的方法獲取的IP實(shí)際上是代理服務(wù)器的地址,并不是客戶端的IP地址。
獲得客戶端真實(shí)IP地址的方法一:
public String getRemortIP(HttpServletRequest request) { if (request.getHeader("x-forwarded-for") == null) { return request.getRemoteAddr(); } return request.getHeader("x-forwarded-for"); }
獲得客戶端真實(shí)IP地址的方法二
public String getIpAddr(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.getRemoteAddr(); } return ip; }
感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!
相關(guān)文章
通用彈出層頁面(兼容IE、firefox)可關(guān)閉控制寬高及屏蔽背景
本人搜集整理了一個(gè)通用彈出層頁面(兼容IE、firefox)可關(guān)閉控制寬高及屏蔽背景,需要的朋友可以了解下2012-12-12struts2中一個(gè)表單中提交多個(gè)請求的例子(多個(gè)提交按鈕)
在很多Web應(yīng)用中,為了完成不同的工作,一個(gè)HTML form標(biāo)簽中可能有兩個(gè)或多個(gè)submit按鈕,Struts2中提供了另外一種方法,使得無需要配置可以在同一個(gè)action類中執(zhí)行不同的方法(默認(rèn)執(zhí)行的是execute方法)2014-04-04訪問JSP文件或者Servlet文件時(shí)提示下載的解決方法
在訪問JSP文件或者Servlet的時(shí)候,如果提示下載并保存問題的解決方法。2009-09-09關(guān)于request.getHeader("Referer")的問題探討
request.getHeader("Referer")獲取上次訪問的URL鏈接,在什么情況下他會(huì)出現(xiàn)問題,下面為大家分享下,感興趣的朋友不要錯(cuò)過2013-10-10JSP過濾器防止Xss漏洞的實(shí)現(xiàn)方法(分享)
下面小編就為大家?guī)硪黄狫SP過濾器防止Xss漏洞的實(shí)現(xiàn)方法(分享)。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-04-04