本文目錄一覽:
php獲取本機真實IP地址實例代碼
本文實例為大家分享了php獲取本機真實IP地址實例代碼,供大家參考。
主要是獲取操作系統為win2000/xp、win7的本機IP真實地址,和獲取操作系統為linux類型的本機IP真實地址,具體內容如下
function
getLocalIP()
{
$preg
=
“/\A((([0-9]?[0-9])|(1[0-9]{2})|(2[0-4][0-9])|(25[0-5]))\.){3}(([0-9]?[0-9])|(1[0-9]{2})|(2[0-4][0-9])|(25[0-5]))\Z/”;
//獲取操作系統為win2000/xp、win7的本機IP真實地址
exec(“ipconfig”,
$out,
$stats);
if
(!empty($out))
{
foreach
($out
AS
$row)
{
if
(strstr($row,
“IP”)
strstr($row,
“:”)
!strstr($row,
“IPv6”))
{
$tmpIp
=
explode(“:”,
$row);
if
(preg_match($preg,
trim($tmpIp[1])))
{
return
trim($tmpIp[1]);
}
}
}
}
//獲取操作系統為linux類型的本機IP真實地址
exec(“ifconfig”,
$out,
$stats);
if
(!empty($out))
{
if
(isset($out[1])
strstr($out[1],
‘addr:’))
{
$tmpArray
=
explode(“:”,
$out[1]);
$tmpIp
=
explode(“
“,
$tmpArray[1]);
if
(preg_match($preg,
trim($tmpIp[0])))
{
return
trim($tmpIp[0]);
}
}
}
return
‘127.0.0.1’;
}
以上就是本文的全部內容,希望對大家的學習有所幫助。
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怎麼獲取用戶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();
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
原創文章,作者:簡單一點,如若轉載,請註明出處:https://www.506064.com/zh-hant/n/129992.html