request方法客戶端ip: request.getremoteaddr() 輸出:192.168.0.106但是在通過了 apache,squid等反向**軟體就不能獲取到客戶端的真實ip位址了。客戶端主機名:request.getremotehost()輸出:abc
request.getheader("host") 輸出:192.168.0.1:8080
web伺服器名字:request.getservername()輸出:192.168.0.1
伺服器監聽的埠:request.getserverport()輸出:8080
經過**以後,由於在客戶端和服務之間增加了中間層,因此伺服器無法直接拿到客戶端的 ip,伺服器端應用也無法直接通過**請求的位址返回給客戶端。
但是在**請求的http頭資訊中,增加了x-forwarded-for資訊。用以跟蹤 原有的客戶端ip位址和原來客戶端請求的伺服器位址。
當我們訪問index.jsp/時,其實並不是我們瀏覽器真正訪問到了伺服器上的index.jsp 檔案,而是先由**伺服器去訪問index.jsp ,
**伺服器再將訪問到的結果返回給我們的瀏覽器,因為是**伺服器去訪問index.jsp的,
所以index.jsp中通過 request.getremoteaddr()的方法獲取的ip實際上是**伺服器的位址,並不是客戶端的ip位址。
}
在很多應用下都可能有需要將使用者的真實ip記錄下來,這時就要獲得使用者的真實ip位址,在jsp裡,獲取客戶端的ip位址的方法是:request.getremoteaddr(),這種方法在大部分情況下都是有效的。但是在通過了apache,squid等反向**軟體就不能獲取到客戶端的真實ip位址了。分類: strut
獲取真實IP
servlet request getheader x forwarded for 獲取真實ip request方法客戶端ip request.getremoteaddr 輸出 192.168.0.106 客戶端主機名 request.getremotehost 輸出 abc request.get...
獲取真實的ip教程
場景一 無cdn情況 直接通過預設方法獲取 httpcontext.current.request.userhostaddress 場景二 阿里雲cdn 當乙個七層 伺服器 如高防ip 把使用者的訪問請求轉到後端伺服器時,源站預設看到的是這個七層 伺服器 如高防ip 的回源ip。而真實的客戶端ip會...
CDN獲取真實IP
現在很多 用了cdn技術,在做一些測試的時候,想獲取其伺服器真實ip位址就有點困難,不知道現在還有其他什麼好的方法呢,整理了下,目前知道如下兩種 1 拿cdn伺服器 找出真實ip cache peer 1.1.1.1 parent 80 0 no query originserver cache p...