php獲取代理真實ip,php使用代理

本文目錄一覽:

php如何查詢來訪的真實IP地址,端口映射後?

理論上不可能獲得真實的客戶IP地址,只能獲得最後一次路由器、或者代理服務器的IP地址。典型的情況是對方也在局域網、或者防火牆的後面,我們是不可能獲得他真實的IP地址的,其實獲取來也沒有,一般是192.168.1.2這樣的私有地址,甚至很可能所有的客戶機都是這個網段。

PHP如何獲取客戶端真實IP

如果將這個函數應用到限IP訪問的網頁中,別人即使通過限IP訪問段中的代理服務器,也不能訪問該頁面。

下面提供一個函數:?php

// 定義一個函數getIP()

function getIP(){global $ip;

if (getenv(“HTTP_CLIENT_IP”))

$ip = getenv(“HTTP_CLIENT_IP”);

else if(getenv(“HTTP_X_FORWARDED_FOR”))

$ip = getenv(“HTTP_X_FORWARDED_FOR”);

else if(getenv(“REMOTE_ADDR”))

$ip = getenv(“REMOTE_ADDR”);else$ip = “Unknow”;

return $ip;}

// 使用方法:

echo getIP();?

getenv(“REMOTE_ADDR”)用來取得客戶端的 IP 地址,但如果客戶端是使用代理服務器來訪問,那取到的就是代理服務器的 IP 地址,而不是真正的客戶端 IP 地址。要想透過代理服務器取得客戶端的真實 IP 地址,就要使用 getenv(“HTTP_X_FORWARDED_FOR”) 來讀取。

但是如果客戶端沒有通過代理服務器來訪問,那麼用getenv(“HTTP_X_FORWARDED_FOR”) 取到的值將是空的。

else if(getenv(“HTTP_X_FORWARDED_FOR”))

$ip = getenv(“HTTP_X_FORWARDED_FOR”);

表示如果getenv(“HTTP_X_FORWARDED_FOR”) 取到的值存在不為空(即客戶端使用代理服務器的情況下),則變量$ip等於getenv(“HTTP_X_FORWARDED_FOR”) 取到的真實IP值。

如果上面的else if(getenv(“HTTP_X_FORWARDED_FOR”))取得的值為空(即沒有使用代理服務器),則不會執行下面的$ip = getenv(“HTTP_X_FORWARDED_FOR”);這一行語句。

這種情況下已經確認客戶端沒有使用代理服務器,從而通過

else if(getenv(“REMOTE_ADDR”))

如何利用php獲取url反向代理後面的真實地址?

下面的代碼用於獲得真實的客戶端ip,俗話說,道高一尺魔高一丈,更高級的偽裝能夠騙過這種檢測也有可能,不過至少讓偽裝的門檻提高不少。

function getip() {

$unknown = ‘unknown’;

if ( isset($_SERVER[‘HTTP_X_FORWARDED_FOR’]) $_SERVER[‘HTTP_X_FORWARDED_FOR’] strcasecmp($_SERVER[‘HTTP_X_FORWARDED_FOR’], $unknown) ) {

$ip = $_SERVER[‘HTTP_X_FORWARDED_FOR’];

} elseif ( isset($_SERVER[‘REMOTE_ADDR’]) $_SERVER[‘REMOTE_ADDR’] strcasecmp($_SERVER[‘REMOTE_ADDR’], $unknown) ) {

$ip = $_SERVER[‘REMOTE_ADDR’];

}

/*

處理多層代理的情況

或者使用正則方式:$ip = preg_match(“/[\d\.]{7,15}/”, $ip, $matches) ? $matches[0] : $unknown;

*/

if (false !== strpos($ip, ‘,’))

$ip = reset(explode(‘,’, $ip));

return $ip;

}

需要做下簡單解釋:

一、沒有使用代理服務器的PHP獲取客戶端IP情況:

REMOTE_ADDR = 客戶端IP

HTTP_X_FORWARDED_FOR = 沒數值或不顯示

二、使用透明代理服務器的情況:Transparent Proxies

REMOTE_ADDR = 最後一個代理服務器 IP

HTTP_X_FORWARDED_FOR = 客戶端真實 IP (經過多個代理服務器時,這個值類似:221.5.252.160, 203.98.182.163, 203.129.72.215)

這類代理服務器還是將客戶端真實的IP發送給了訪問對象,無法達到隱藏真實身份的目的.

三、使用普通匿名代理服務器的PHP獲取客戶端IP情況:Anonymous Proxies

REMOTE_ADDR = 最後一個代理服務器 IP

HTTP_X_FORWARDED_FOR = 代理服務器 IP (經過多個代理服務器時,這個值類似:203.98.182.163, 203.98.182.163, 203.129.72.215)

這種情況下隱藏了客戶端的真實IP,但是向訪問對象透露了客戶端是使用代理服務器訪問它們的.

四、使用欺騙性代理服務器的情況:Distorting Proxies

REMOTE_ADDR = 代理服務器 IP

HTTP_X_FORWARDED_FOR = 隨機的 IP(經過多個代理服務器時,這個值類似:220.4.251.159, 203.98.182.163, 203.129.72.215)

這種情況下同樣透露了客戶端是使用了代理服務器,但編造了一個虛假的隨機IP(220.4.251.159)代替客戶端的真實IP來欺騙它.

五、使用高匿名代理服務器的PHP獲取客戶端IP情況:High Anonymity Proxies (Elite proxies)

REMOTE_ADDR = 代理服務器 IP

HTTP_X_FORWARDED_FOR = 沒數值或不顯示

無論是REMOTE_ADDR還是HTTP_FORWARDED_FOR,這些頭消息未必能夠取得到,因為不同的瀏覽器不同的網絡設備可能發送不同的IP頭消息.因此PHP使用$_SERVER[“REMOTE_ADDR”] 、$_SERVER[“HTTP_X_FORWARDED_FOR”] 獲取的值可能是空值也可能是「unknown」值.

php怎樣獲取用戶真實ip?

獲取客戶端ip其實不是個簡單的事兒,因為存在IP欺騙,和代理問題,所以獲取客戶端的IP的真實性會打折扣的,不能百分百準確。但是我們還是可以盡量寫一些比較完善的獲取客戶端真正ip方法。使用php獲取IP的方法能有很多,我簡單給個例子:

?php

function getip() { 

     $unknown = ‘unknown’; 

     if(isset($_SERVER[‘HTTP_X_FORWARDED_FOR’])  $_SERVER[‘HTTP_X_FORWARDED_FOR’]  strcasecmp($_SERVER[‘HTTP_X_FORWARDED_FOR’], $unknown)){ 

         $ip = $_SERVER[‘HTTP_X_FORWARDED_FOR’]; 

     }elseif(isset($_SERVER[‘REMOTE_ADDR’])  $_SERVER[‘REMOTE_ADDR’]  strcasecmp($_SERVER[‘REMOTE_ADDR’], $unknown)) { 

         $ip = $_SERVER[‘REMOTE_ADDR’]; 

     } 

     /**

      * 處理多層代理的情況

      * 或者使用正則方式:$ip = preg_match(“/[\d\.]{7,15}/”, $ip, $matches) ? $matches[0] : $unknown;

      */

     if (false !== strpos($ip, ‘,’)) $ip = reset(explode(‘,’, $ip)); 

     return $ip; 

?

1、沒有使用代理的情況

REMOTE_ADDR = 客戶端IP

    HTTP_X_FORWARDED_FOR = 沒數值或不顯示

2、使用透明代理的情況

REMOTE_ADDR = 最後一個代理服務器 IP

    HTTP_X_FORWARDED_FOR = 客戶端真實 IP (經過多個代理服務器時,這個值類似:        221.5.252.160, 203.98.182.163, 203.129.72.215)

    這類代理服務器還是將客戶端真實的IP發送給了訪問對象,無法達到隱藏真實身份的目的.

3、使用普通的匿名代理

REMOTE_ADDR = 最後一個代理服務器 IP

    HTTP_X_FORWARDED_FOR = 代理服務器 IP (經過多個代理服務器時,這個值類似:        203.98.182.163, 203.98.182.163, 203.129.72.215)

    這種情況下隱藏了客戶端的真實IP,但是向訪問對象透露了客戶端是使用代理服務器訪問它        們的.

4、使用欺騙性代理服務器

REMOTE_ADDR = 代理服務器 IP

    HTTP_X_FORWARDED_FOR = 隨機的 IP(經過多個代理服務器時,這個值類似:                    220.4.251.159, 203.98.182.163, 203.129.72.215)

    這種情況下同樣透露了客戶端是使用了代理服務器,但編造了一個虛假的隨機                            IP(220.4.251.159)代替客戶端的真實IP來欺騙它.

5、使用高級匿名代理服務器

REMOTE_ADDR = 代理服務器 IP

    HTTP_X_FORWARDED_FOR = 沒數值或不顯示,也可能是unknown

php 獲取真實IP,區分代理IP

使用php獲取IP的方法能找到很多。

function getIp(){

if (getenv(“HTTP_CLIENT_IP”) strcasecmp(getenv(“HTTP_CLIENT_IP”), “unknown”))

$ip = getenv(“HTTP_CLIENT_IP”);

else if (getenv(“HTTP_X_FORWARDED_FOR”) strcasecmp(getenv(“HTTP_X_FORWARDED_FOR”), “unknown”))

$ip = getenv(“HTTP_X_FORWARDED_FOR”);

else if (getenv(“REMOTE_ADDR”) strcasecmp(getenv(“REMOTE_ADDR”), “unknown”))

$ip = getenv(“REMOTE_ADDR”);

else if (isset($_SERVER[‘REMOTE_ADDR’]) $_SERVER[‘REMOTE_ADDR’] strcasecmp($_SERVER[‘REMOTE_ADDR’], “unknown”))

$ip = $_SERVER[‘REMOTE_ADDR’];

else

$ip = “unknown”;

return($ip);

}

對這段代碼進行解釋,這裡用到了兩個函數,getenv()和strcasecmp(),前一個函數獲取得系統的環境變量,如果能取到值,則返回該值,不能則返回false.

$_SERVER是服務器超級全局變量數組,用$_SERVER[‘REMOTE_ADDR’]同樣可以獲取到客戶端的IP地址.二者的區別在於,getenv不支持IIS的isapi方式運行的php.

strcasecmp(string1,string2)字符串函數的用法是把string1和string2進行比較,如果相等返回0,如果string1大於string2,返回大於0的數,小於則返回小於0的數.

函數先使用客戶IP,如果不成立嘗試用代理的方法,如果不行,再使用REMOTE_ADDR。

原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-hk/n/240135.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
小藍的頭像小藍
上一篇 2024-12-12 12:20
下一篇 2024-12-12 12:20

相關推薦

  • PHP和Python哪個好找工作?

    PHP和Python都是非常流行的編程語言,它們被廣泛應用於不同領域的開發中。但是,在考慮擇業方向的時候,很多人都會有一個問題:PHP和Python哪個好找工作?這篇文章將從多個方…

    編程 2025-04-29
  • Centos7配置靜態ip

    本文將詳細闡述如何在Centos7系統中配置靜態ip。 一、查看網絡接口 在配置靜態ip之前,我們首先需要查看系統中的網絡接口,以確定我們需要配置的網卡是哪一個。 ifconfig…

    編程 2025-04-29
  • PHP怎麼接幣

    想要在自己的網站或應用中接受比特幣等加密貨幣的支付,就需要對該加密貨幣擁有一定的了解,並使用對應的API進行開發。本文將從多個方面詳細闡述如何使用PHP接受加密貨幣的支付。 一、環…

    編程 2025-04-29
  • Python檢測IP連通

    Python是一門強大的編程語言,常用於網絡開發、數據分析等領域。IP地址是網絡通信的基礎,在網絡通信中,有時需要檢測IP地址是否連通。下面將從多個方面介紹Python檢測IP連通…

    編程 2025-04-28
  • 使用PHP foreach遍歷有相同屬性的值

    本篇文章將介紹如何使用PHP foreach遍歷具有相同屬性的值,並給出相應的代碼示例。 一、基礎概念 在講解如何使用PHP foreach遍歷有相同屬性的值之前,我們需要先了解幾…

    編程 2025-04-28
  • Treck TCP/IP Stack 輸入驗證錯誤漏洞CVE-2020-11901解析

    本文將對Treck TCP/IP Stack 輸入驗證錯誤漏洞CVE-2020-11901進行詳細解析,並提供相關代碼示例。 一、漏洞背景 Treck TCP/IP Stack是一…

    編程 2025-04-27
  • PHP獲取301跳轉後的地址

    本文將為大家介紹如何使用PHP獲取301跳轉後的地址。301重定向是什麼呢?當我們訪問一個網頁A,但是它已經被遷移到了另一個地址B,此時若服務器端做了301重定向,那麼你的瀏覽器在…

    編程 2025-04-27
  • PHP登錄頁面代碼實現

    本文將從多個方面詳細闡述如何使用PHP編寫一個簡單的登錄頁面。 1. PHP登錄頁面基本架構 在PHP登錄頁面中,需要包含HTML表單,用戶在表單中輸入賬號密碼等信息,提交表單後服…

    編程 2025-04-27
  • PHP與Python的比較

    本文將會對PHP與Python進行比較和對比分析,包括語法特性、優缺點等方面。幫助讀者更好地理解和使用這兩種語言。 一、語法特性 PHP語法特性: <?php // 簡單的P…

    編程 2025-04-27
  • PHP版本管理工具phpenv詳解

    在PHP項目開發過程中,我們可能需要用到不同版本的PHP環境來試驗不同的功能或避免不同版本的兼容性問題。或者我們需要在同一台服務器上同時運行多個不同版本的PHP語言。但是每次手動安…

    編程 2025-04-24

發表回復

登錄後才能評論