In WEB-Anwendungen ist das Auffinden und Aufzeichnen zugehöriger Zugriffsprotokolle auf der Grundlage von IP-Adressen ebenfalls eine sehr häufige Anforderung. In ThinkPHP können Sie problemlos IP-Adressen abrufen und lokalisieren.
Sie können die IP-Positionierungserweiterungsklasse herunterladen die offizielle Website-Bibliothek oder laden Sie das Erweiterungspaket herunter, das bereits die Erweiterungsklasse enthält. Wenn die hochgeladene Klassenbibliothek separat heruntergeladen wird, legen Sie die dekomprimierte Datei IpLocation.class.php im Verzeichnis ThinkPHP/Extend/Library/ORG/Net/ ab (bitte erstellen Sie sie manuell, falls sie nicht vorhanden ist).
1. Erhalten Sie die IP-Adresse
Wenn Sie nur die vom Benutzer besuchte IP-Adresse erhalten müssen, verwenden Sie direkt die integrierte Funktion get_client_ip Methode im ThinkPHP-Standardmodus und kann direkt verwendet werden. Sie ist besser kompatibel als die in PHP integrierte Systemvariable $_SERVER['HTTP_CLIENT_IP']. Verwendung:
$ip = get_client_ip();
get_client_ip unterstützt die Erkennung mehrerer Situationen und die Überprüfung der Rechtmäßigkeit IP-Adressen. Der Rückgabewert ist die erhaltene IP-Adresse. Wenn die erhaltene IP-Adresse illegal ist, wird 0.0.0.0 zurückgegeben.
Auf Wunsch können auch IPV4-Adressnummern zurückgegeben werden, zum Beispiel:
$ip = get_client_ip(1);
Die zurückgegebenen Ergebnisse können wie folgt aussehen:
2130706433
Kann für Adressbereiche und Vergleiche verwendet werden.
2. IP-Adresspositionierung
Das bloße Abrufen der IP-Adresse kann die Anforderungen der Anwendung nicht vollständig erfüllen. Sie kann nur für zukünftige Protokollanalyseanforderungen aufgezeichnet werden Bereich. . Um die IP-Standortfunktion zu verwenden, benötigen Sie zusätzlich zur IpLocation-Erweiterungsklassenbibliothek auch eine IP-Adressbibliotheksdatei. Da ThinkPHP standardmäßig die UTF8-Codierung verwendet, ist es am besten, eine IP-Adressbibliotheksdatei im UTF8-Format zu verwenden Wenn es sich um eine reine GBK-codierte IP-Adressbibliotheksdatei handelt, müssen Sie eine Codierungskonvertierung für die erhaltenen Ergebnisse durchführen (siehe unten).
Die dekomprimierte Adressbibliotheksdatei UTFWry.dat kann in dem Verzeichnis abgelegt werden, in dem sich die IpLocation-Erweiterungsklassenbibliothek befindet.
Verwendung:
import('ORG.Net.IpLocation');// 导入IpLocation类 $Ip = new IpLocation(); // 实例化类 $location = $Ip->getlocation('218.79.93.194'); // 获取某个IP地址所在的位置
Die zurückgegebene Standortvariable ist ein Array, einschließlich:
$location['ip'] // IP地址 $location['beginip'] // 用户IP所在范围的开始地址 $location['endip'] // 用户IP所在范围的结束地址 $location['country'] // 所在国家或者地区 $location['area'] // 所在区域
Wenn wir den IP-Standort erhalten möchten, müssen wir normalerweise nur die Land- und Gebietsinformationen abrufen :
$info = $location['country'].$location['area'];
Wenn die von Ihnen verwendete IP-Adressbibliotheksdatei nicht UTFWry.dat ist (beachten Sie, dass die Groß- und Kleinschreibung des Dateinamens unter Linux ebenfalls konsistent sein muss), müssen wir den Namen der Adressbibliotheksdatei übergeben, wenn Instanziieren der IpLocation-Klasse, zum Beispiel:
$Ip = new IpLocation('MyIpWry.dat'); // 传入IP地址库文件名
Wenn Ihre IP-Adressbibliothek in GBK codiert ist, müssen Sie den Code des zurückgegebenen Ergebnisses konvertieren. Beispiel:
$info = iconv('gbk','utf-8',$location['country'].$location['area']);
Wenn beim Aufruf der getlocation-Methode keine Parameter übergeben werden, ruft das System automatisch die obige Funktion get_client_ip auf, um die aktuelle IP-Adresse abzurufen:
$location = $Ip->getlocation();
Es kann auch die Übergabe unterstützen in Domain-Namen, um automatisch die IP-Adresse zu erhalten
import('ORG.Net.IpLocation');// 导入IpLocation类 $Ip = new IpLocation(); // 实例化类 $area = $Ip->getlocation('www.thinkphp.cn'); // 获取域名服务器所在的位置 dump($area);
Ausgabe des laufenden Ergebnisses:
Wenn Sie eine reine IP-Adressbibliothek verwenden oder häufig verwenden Aus Bequemlichkeitsgründen müssen verschiedene Adressbibliotheken geändert werden. Für IP-Positionierungsabfragen können Sie auch eine separate Funktion zum Abrufen von Standortinformationen kapseln.
Das Obige ist der gesamte Inhalt dieses Artikels. Ich hoffe, er wird für das Studium aller hilfreich sein. Weitere verwandte Inhalte finden Sie auf der chinesischen PHP-Website.
Verwandte Empfehlungen:
Über die Tabellenmethode der ThinkPHP CURD-Methode
THinkPHP erhält die Client-IP- und IP-Adressabfrage Methode
Das obige ist der detaillierte Inhalt vonInformationen dazu, wie ThinkPHP die UTFWry-Adressbibliothek für die IP-Positionierung verwendet. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!