在WEB應用程式中,根據IP位址定位和記錄相關存取日誌也是非常常見的需求,在ThinkPHP中你可以輕鬆的實現IP位址獲取和定位
可以在官網下載IP定位擴展類庫,或者下載擴充包裡面也已經包含該擴充類別了。如果是單獨下載的上傳類別庫,把解壓縮後的IpLocation.class.php 放入ThinkPHP/Extend/Library/ORG/Net/(如果沒有請手動建立)目錄下方。
一、取得IP位址
如果你只需要取得使用者存取的IP位址,那麼直接使用系統內建的get_client_ip函數即可,該函數是ThinkPHP標準模式內建方法,可以直接使用,比PHP內建的系統變數$_SERVER['HTTP_CLIENT_IP']具有更好的相容性,用法:
$ip = get_client_ip();
get_client_ip支援IP位址的多種情況偵測和合法性驗證,傳回值就是取得到的IP位址,如果取得到的IP位址非法,將回傳0.0.0.0。
如果需要,也可以傳回IPV4位址數字,例如:
$ip = get_client_ip(1);
傳回的結果可能類似於:
2130706433
可用於位址範圍和比較。
二、IP位址定位
僅僅取得IP位址並不能完全滿足應用的需求,只能記錄下來用於日後的日誌分析需要,IP位址定位功能可以讓你取得使用者的所在區域。要使用IP定位功能,除了需要IpLocation擴充類別庫之外,還需要IP位址庫文件,由於ThinkPHP預設採用UTF8編碼,因此最好是UTF8格式的IP位址庫文件,如果是純真gbk編碼的IP位址庫文件,則需要對獲取結果進行編碼轉換(下面會提到)
解壓縮後的地址庫文件UTFWry.dat放入IpLocation擴展類庫所在目錄下面即可。
使用方法:
import('ORG.Net.IpLocation');// 导入IpLocation类 $Ip = new IpLocation(); // 实例化类 $location = $Ip->getlocation('218.79.93.194'); // 获取某个IP地址所在的位置
傳回的location變數是數組,包含:
$location['ip'] // IP地址 $location['beginip'] // 用户IP所在范围的开始地址 $location['endip'] // 用户IP所在范围的结束地址 $location['country'] // 所在国家或者地区 $location['area'] // 所在区域
通常,我們要取得IP定位的話,只需要取country和area資訊:
$info = $location['country'].$location['area'];
如果你使用的IP位址庫檔案不是UTFWry.dat(注意在Linux下面檔案名稱的大小寫也需要一致)的話,我們需要在實例化IpLocation類別的時候傳入位址庫檔案名,例如:
$Ip = new IpLocation('MyIpWry.dat'); // 传入IP地址库文件名
如果你的IP位址庫是GBK編碼的話,需要對回傳結果進行編碼轉換。例如:
$info = iconv('gbk','utf-8',$location['country'].$location['area']);
如果呼叫getlocation方法的時候沒有傳入任何參數,系統會自動呼叫上面的get_client_ip函數取得目前所在IP位址:
$location = $Ip->getlocation();
也可以支援傳入網域來自動取得ip位址
import('ORG.Net.IpLocation');// 导入IpLocation类 $Ip = new IpLocation(); // 实例化类 $area = $Ip->getlocation('www.thinkphp.cn'); // 获取域名服务器所在的位置 dump($area);
運行結果輸出:
#如果大家使用的是純真IP位址庫,或經常需要變換不同的位址庫,為了方便IP定位的查詢,也可以單獨封裝一個函數來取得位置資訊。
以上就是本文的全部內容,希望對大家的學習有所幫助,更多相關內容請關注PHP中文網!
相關推薦:
#
以上是關於ThinkPHP使用UTFWry位址庫進行IP定位的方法的詳細內容。更多資訊請關注PHP中文網其他相關文章!