php獲取用戶真實,php獲取用戶真實ip

本文目錄一覽:

利用php怎麼獲取用戶ip

php獲取用戶真實ip的方法:

方法1:

//獲取REMOTE_ADDR屬性,直接可以得到ip

$ip = $_SERVER[“REMOTE_ADDR”];

echo $ip;

方法2:

//從Server中獲取HTTP_VIA,如果獲取到就用HTTP_X_FORWARDED_FOR的值替換,如果獲取不到就取REMOTE_ADDR的值。

$user_IP = ($_SERVER[“HTTP_VIA”]) ? $_SERVER[“HTTP_X_FORWARDED_FOR”] :

$_SERVER[“REMOTE_ADDR”];

$user_IP = ($user_IP) ? $user_IP : $_SERVER[“REMOTE_ADDR”];

echo $user_IP;

方法3:

function getRealIp()

{

$ip=false; //初始化ip為false

if(!empty($_SERVER[“HTTP_CLIENT_IP”])){ //如果HTTP_CLIENT_IP不為空

$ip = $_SERVER[“HTTP_CLIENT_IP”]; //獲取HTTP_CLIENT_IP的值

}

if (!empty($_SERVER[‘HTTP_X_FORWARDED_FOR’])) { //如果HTTP_X_FORWARDED_FOR不為空

$ips = explode (“, “, $_SERVER[‘HTTP_X_FORWARDED_FOR’]);

//把HTTP_X_FORWARDED_FOR的值用,分割後存放數組ips

if ($ip) { array_unshift($ips, $ip); $ip = FALSE; }//遍歷處理

for ($i = 0; $i count($ips); $i++) {

if (!eregi (“^(10│172.16│192.168).”, $ips[$i])) {

$ip = $ips[$i]; //獲得真實ip

break;

}

}

}

return ($ip ? $ip : $_SERVER[‘REMOTE_ADDR’]);

}

echo getRealIp();

如何準確獲取用戶真實ip php

function GetIP() {

  if (getenv(‘HTTP_CLIENT_IP’)  strcasecmp(getenv(‘HTTP_CLIENT_IP’),’unknown’)) {

        $onlineip = getenv(‘HTTP_CLIENT_IP’);

      } elseif (getenv(‘HTTP_X_FORWARDED_FOR’)  strcasecmp(getenv(‘HTTP_X_FORWARDED_FOR’),’unknown’)) {

        $onlineip = getenv(‘HTTP_X_FORWARDED_FOR’);

      } elseif (getenv(‘REMOTE_ADDR’)  strcasecmp(getenv(‘REMOTE_ADDR’),’unknown’)) {

        $onlineip = getenv(‘REMOTE_ADDR’);

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

        $onlineip = $_SERVER[‘REMOTE_ADDR’];

    }

  return $onlineip;

}

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地址??

你是在本機測試的嗎?如果是在本機測試,那肯定就是127.0.0.1了,你上傳到服務器上訪問就會出真實的IP了

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”))

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

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
DEVN的頭像DEVN
上一篇 2024-10-04 00:23
下一篇 2024-10-04 00:23

相關推薦

  • 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中接收用戶的輸入

    Python中接收用戶的輸入是一個常見的任務,可以通過多種方式來實現。本文將從以下幾個方面對Python中接收用戶的輸入做詳細闡述。 一、使用input函數接收用戶輸入 Pytho…

    編程 2025-04-29
  • Python彈框讓用戶輸入

    本文將從多個方面對Python彈框讓用戶輸入進行闡述,並給出相應的代碼示例。 一、Tkinter彈窗 Tkinter是Python自帶的圖形用戶界面(GUI)庫,通過它可以創建各種…

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

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

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

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

    編程 2025-04-28
  • Zookeeper ACL 用戶 anyone 全面解析

    本文將從以下幾個方面對Zookeeper ACL中的用戶anyone進行全面的解析,並為讀者提供相關的示例代碼。 一、anyone 的作用是什麼? 在Zookeeper中,anyo…

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

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

    編程 2025-04-27
  • Python中獲取用戶輸入命令的方法解析

    本文將從多個角度,分別介紹Python中獲取用戶輸入命令的方法,希望能夠對初學者有所幫助。 一、使用input()函數獲取用戶輸入命令 input()是Python中用於獲取用戶輸…

    編程 2025-04-27

發表回復

登錄後才能評論