經過**以後,由於在客戶端和服務之間增加了中間層,因此伺服器無法直接拿到客戶端的ip,伺服器端應用也無法直接通過**請求的位址返回給客戶端。但是在**請求的http頭資訊中,增加了x-forwarded-for資訊。用以跟蹤原有的客戶端ip位址和原來客戶端請求的伺服器位址。
例如:使用反向**,將的url反向**為時,用 request.getremoteaddr() 方法獲取的ip位址是:127.0.0.1或192.168.10.1,而並不是客戶端的真實ip。也就是說訪問,是經過**伺服器訪問的,因此request.getremoteaddr()獲取的ip其實是**伺服器的ip。
(1)方法一
}(2)方法二:squid.conf 的配製檔案 forwarded_for 項預設是為on,如果 forwarded_for 設成了 off 則:x-forwarded-for: unknown
//equalsignorecase將字串與指定的物件比較,不考慮大小寫。
//isblank 字串為空、長度為0或由空白符組成
}
(3)如果使用多級反向**,x-forwarded-for的值並不止乙個,獲取到的是一串ip值。
}參考:go
go
獲取客戶端真實ip
很多時候我們需要獲取客戶端的訪問ip,ip位址合法驗證 long sprintf u ip2long ip ip long array ip,long array 0.0.0.0 0 return ip type 一 如果沒有使用 伺服器,remote addr 客戶端iphttp x forwar...
獲取客戶端真實IP
server http x real ip nginx 模式下,獲取客戶端真實ip server http client ip 端的 有可能存在,可偽造 server http x forwarded for 使用者是在哪個ip使用的 有可能存在,也可以偽造 server http cdn src ...
獲取客戶端真實IP
在jsp裡,獲取客戶端的ip位址的方法是 request.getremoteaddr 這種方法在大部分情況下都是有效的。但是在通過了 apache,nagix等反向 軟體就不能獲取到客戶端的真實ip位址了。如果使用了反向 軟體,用 request.getremoteaddr 經過 以後,由於在客戶端...