php中獲取指定IP的物理地址的代碼(正則表達式)
更新時間:2011年06月23日 13:08:54 作者:
網(wǎng)站常用的模塊可能出了注冊、登陸、發(fā)稿、留言、評論,剩下比較重要的也許就是獲取IP并作相應的數(shù)據(jù)處理了。
自己搭建IP數(shù)據(jù)庫占資源,而且更新不便,何不使用現(xiàn)成的IP查詢呢?下面自己寫了個獲取IP物理地址的PHP代碼(有一定的瑕疵,請高手不吝賜教)
<!DOCTYPE html>
<html lang="en">
<head>
<title></title>
<meta charset="UTF-8" />
<meta name="author" content="" />
<meta name="keywords" content="" />
<meta name="description" content="" />
</head>
<body>
<?php
$ipAddr = "218.75.124.100";
$ip138Addr = "http://www.ip138.com/ips8.asp?ip=".$ipAddr."&action=2";
$contents = file_get_contents($ip138Addr);
$pattern = "/\<li.+?\/li\>/";
$string = $contents;
preg_match_all($pattern,$string,$addrArray);
$num = count($addrArray[0]);
for($i = 0;$i<$num;$i++){
echo $addrArray[0][$i] = mb_convert_encoding($addrArray[0][$i],"UTF-8", "GB2312");
switch($i) {
case 0:$str = "<li>本站主數(shù)據(jù):</li>";break;
case 1:$str = "<li>參考數(shù)據(jù)一:</li>";break;
case 2:$str = "<li>參考數(shù)據(jù)二:</li>";break;
case 3:$str = "<li>參考數(shù)據(jù)三:</li>";break;
case 4:$str = "<li>參考數(shù)據(jù)四:</li>";break;
case 5:$str = "<li>參考數(shù)據(jù)六:</li>";break;
case 6:$str = "<li>參考數(shù)據(jù)七:</li>";break;
}
$addrArray[0][$i] = trim($addrArray[0][$i],$str);
}
$addrArray[0][0] = trim($addrArray[0][0],":");
echo "<pre>";
print_r($addrArray);
echo "</pre>";
?>
</body>
</html>
這段代碼采用訪問http://www.ip138.com后使用正則表達式進行截取部分內(nèi)容,其中正則表達式是自己寫的。

開始還好,下面的處理結果出現(xiàn)了亂碼,如果把$str(去除字符串首尾的標識)定義的字符串就沒有了亂碼;而且再加一個單獨的去除“:”的語句,就可以實現(xiàn)無亂碼的現(xiàn)象,不知道為什么了……
正則表達式——獲取指定IP的物理地址(二) chinaz數(shù)據(jù)
上一個IP獲取的結果不是很完善,究其原因是因為ip138的IP解析應對國外的地址時不是很詳細,所以又重新寫了個用Chianz.com的代碼。
<!DOCTYPE html>
<html lang="en">
<head>
<title></title>
<meta charset="UTF-8" />
<meta name="author" content="" />
<meta name="keywords" content="" />
<meta name="description" content="" />
</head>
<body>
<?php
$ipAddr = "4.4.44.4";
$ipChinazAddr = "http://tool.chinaz.com/IP/?IP=".$ipAddr;
$contents = file_get_contents($ipChinazAddr);
$pattern = "/\=\=\>\>.+\<\/strong\>\<br \/\>/";
$string = $contents;
preg_match_all($pattern,$string,$addrArray);
$num = count($addrArray[0]);
$pattern = "/(==>>).+(==>>\s)/";
for($i = 0;$i<$num;$i++){
$addrArray[0][$i] = preg_replace($pattern,"",$addrArray[0][$i]);
}
echo "<pre>";
print_r($addrArray);
echo "</pre>";
?>
</body>
</html>
結果還令人滿意
復制代碼 代碼如下:
<!DOCTYPE html>
<html lang="en">
<head>
<title></title>
<meta charset="UTF-8" />
<meta name="author" content="" />
<meta name="keywords" content="" />
<meta name="description" content="" />
</head>
<body>
<?php
$ipAddr = "218.75.124.100";
$ip138Addr = "http://www.ip138.com/ips8.asp?ip=".$ipAddr."&action=2";
$contents = file_get_contents($ip138Addr);
$pattern = "/\<li.+?\/li\>/";
$string = $contents;
preg_match_all($pattern,$string,$addrArray);
$num = count($addrArray[0]);
for($i = 0;$i<$num;$i++){
echo $addrArray[0][$i] = mb_convert_encoding($addrArray[0][$i],"UTF-8", "GB2312");
switch($i) {
case 0:$str = "<li>本站主數(shù)據(jù):</li>";break;
case 1:$str = "<li>參考數(shù)據(jù)一:</li>";break;
case 2:$str = "<li>參考數(shù)據(jù)二:</li>";break;
case 3:$str = "<li>參考數(shù)據(jù)三:</li>";break;
case 4:$str = "<li>參考數(shù)據(jù)四:</li>";break;
case 5:$str = "<li>參考數(shù)據(jù)六:</li>";break;
case 6:$str = "<li>參考數(shù)據(jù)七:</li>";break;
}
$addrArray[0][$i] = trim($addrArray[0][$i],$str);
}
$addrArray[0][0] = trim($addrArray[0][0],":");
echo "<pre>";
print_r($addrArray);
echo "</pre>";
?>
</body>
</html>
這段代碼采用訪問http://www.ip138.com后使用正則表達式進行截取部分內(nèi)容,其中正則表達式是自己寫的。

開始還好,下面的處理結果出現(xiàn)了亂碼,如果把$str(去除字符串首尾的標識)定義的字符串就沒有了亂碼;而且再加一個單獨的去除“:”的語句,就可以實現(xiàn)無亂碼的現(xiàn)象,不知道為什么了……
正則表達式——獲取指定IP的物理地址(二) chinaz數(shù)據(jù)
上一個IP獲取的結果不是很完善,究其原因是因為ip138的IP解析應對國外的地址時不是很詳細,所以又重新寫了個用Chianz.com的代碼。
復制代碼 代碼如下:
<!DOCTYPE html>
<html lang="en">
<head>
<title></title>
<meta charset="UTF-8" />
<meta name="author" content="" />
<meta name="keywords" content="" />
<meta name="description" content="" />
</head>
<body>
<?php
$ipAddr = "4.4.44.4";
$ipChinazAddr = "http://tool.chinaz.com/IP/?IP=".$ipAddr;
$contents = file_get_contents($ipChinazAddr);
$pattern = "/\=\=\>\>.+\<\/strong\>\<br \/\>/";
$string = $contents;
preg_match_all($pattern,$string,$addrArray);
$num = count($addrArray[0]);
$pattern = "/(==>>).+(==>>\s)/";
for($i = 0;$i<$num;$i++){
$addrArray[0][$i] = preg_replace($pattern,"",$addrArray[0][$i]);
}
echo "<pre>";
print_r($addrArray);
echo "</pre>";
?>
</body>
</html>
結果還令人滿意


以上是本人寫的兩個獲取IP物理地址的代碼,作為一個初學者,沒事的時候寫寫簡單的代碼也還是一件挺有意思的事。但是畢竟是一個初學者,不能更好的注意安全性、空間利用率、時間效率等問題,還望各位留下你的足跡,小弟謝了
相關文章
php+mysqli使用面向對象方式查詢數(shù)據(jù)庫實例
這篇文章主要介紹了php+mysqli使用面向對象方式查詢數(shù)據(jù)庫的方法,實例分析了mysqli對象的創(chuàng)建、連接、查詢及返回結果、釋放資源等技巧,需要的朋友可以參考下2015-01-01
PHP設計模式之模板方法模式Template Method Pattern詳解
在我們實際開發(fā)中,如果一個方法極其復雜時,如果我們將所有的邏輯寫在一個方法中,那維護起來就很困難,要替換某些步驟時都要重新寫,這樣代碼的擴展性就很差,當遇到這種情況就要考慮今天的主角——模板方法模式2022-12-12
比較strtr, str_replace和preg_replace三個函數(shù)的效率
本篇文章是對strtr, str_replace和preg_replace三個函數(shù)的效率問題進行了詳細的分析介紹,需要的朋友參考下2013-06-06
深入php define()函數(shù)以及defined()函數(shù)的用法詳解
本篇文章是對php中的define()函數(shù)以及defined()函數(shù)的用法進行了詳細的分析介紹,需要的朋友參考下2013-06-06

