Maison  >  Article  >  développement back-end  >  À propos de la façon dont ThinkPHP utilise la bibliothèque d'adresses UTFWry pour le positionnement IP

À propos de la façon dont ThinkPHP utilise la bibliothèque d'adresses UTFWry pour le positionnement IP

不言
不言original
2018-06-19 15:31:443168parcourir

Dans les applications WEB, la localisation et l'enregistrement des journaux d'accès associés en fonction des adresses IP sont également une exigence très courante. Dans ThinkPHP, vous pouvez facilement obtenir et localiser les adresses IP

Vous pouvez télécharger la classe d'extension de positionnement IP à partir de. la bibliothèque du site officiel, ou téléchargez le package d'extension qui contient déjà la classe d'extension. Si la bibliothèque de classes téléchargée est téléchargée séparément, placez le fichier IpLocation.class.php décompressé dans le répertoire ThinkPHP/Extend/Library/ORG/Net/ (veuillez le créer manuellement s'il n'existe pas).

1. Obtenez l'adresse IP

Si vous avez uniquement besoin d'obtenir l'adresse IP visitée par l'utilisateur, utilisez directement la fonction get_client_ip intégrée au système. méthode en mode standard ThinkPHP et peut être utilisée directement, elle a une meilleure compatibilité que la variable système intégrée de PHP $_SERVER['HTTP_CLIENT_IP']. Utilisation :

$ip = get_client_ip();

get_client_ip prend en charge la détection et la légalité de plusieurs situations. vérification des adresses IP. La valeur de retour est l'adresse IP obtenue. Si l'adresse IP obtenue est illégale, 0.0.0.0 sera renvoyée.
Les numéros d'adresse IPV4 peuvent également être renvoyés si vous le souhaitez, par exemple :

$ip = get_client_ip(1);

Les résultats renvoyés peuvent ressembler à :

2130706433

Peut être utilisé pour des plages d'adresses et des comparaisons.

2. Positionnement de l'adresse IP
La simple obtention de l'adresse IP ne peut pas répondre pleinement aux besoins de l'application. Elle ne peut être enregistrée que pour les besoins futurs d'analyse des journaux. La fonction de positionnement de l'adresse IP vous permet d'obtenir celle de l'utilisateur. zone. . Pour utiliser la fonction de localisation IP, en plus de la bibliothèque de classes d'extension IpLocation, vous avez également besoin d'un fichier de bibliothèque d'adresses IP. Étant donné que ThinkPHP utilise le codage UTF8 par défaut, il est préférable d'utiliser un fichier de bibliothèque d'adresses IP au format UTF8. un fichier de bibliothèque d'adresses IP purement codé en gbk, vous devez effectuer une conversion d'encodage sur les résultats obtenus (mentionnés ci-dessous)
Le fichier de bibliothèque d'adresses décompressé UTFWry.dat peut être placé sous le répertoire où se trouve la bibliothèque de classes d'extension IpLocation.
Utilisation :

import('ORG.Net.IpLocation');// 导入IpLocation类
$Ip = new IpLocation(); // 实例化类
$location = $Ip->getlocation('218.79.93.194'); // 获取某个IP地址所在的位置

La variable de localisation renvoyée est un tableau, comprenant :

$location['ip'] // IP地址
$location['beginip'] // 用户IP所在范围的开始地址
$location['endip'] // 用户IP所在范围的结束地址
$location['country'] // 所在国家或者地区
$location['area'] // 所在区域

Habituellement, si nous voulons obtenir le positionnement IP, il nous suffit d'obtenir le pays et les informations de zone. :

$info =  $location['country'].$location['area'];

Si le fichier de bibliothèque d'adresses IP que vous utilisez n'est pas UTFWry.dat (notez que la casse du nom de fichier sous Linux doit également être cohérente), nous devons le transmettre. l'adresse lors de l'instanciation du nom de fichier de la bibliothèque de classe IpLocation, par exemple :

$Ip = new IpLocation('MyIpWry.dat'); // 传入IP地址库文件名

Si votre bibliothèque d'adresses IP est codée en GBK, vous devez effectuer une conversion d'encodage sur le résultat renvoyé. Par exemple :

$info = iconv('gbk','utf-8',$location['country'].$location['area']);

Si aucun paramètre n'est transmis lors de l'appel de la méthode getlocation, le système appellera automatiquement la fonction get_client_ip ci-dessus pour obtenir l'adresse IP actuelle :

$location = $Ip->getlocation();

peut également être transmis Entrez le nom de domaine pour obtenir automatiquement l'adresse IP

import('ORG.Net.IpLocation');// 导入IpLocation类
$Ip = new IpLocation(); // 实例化类
$area = $Ip->getlocation('www.thinkphp.cn'); // 获取域名服务器所在的位置
dump($area);

Exécutez la sortie du résultat :

À propos de la façon dont ThinkPHP utilise la bibliothèque d'adresses UTFWry pour le positionnement IP

Si vous utilisez une IP pure bibliothèque d'adresses, ou vous devez souvent la remplacer par une autre. Afin de faciliter la requête de localisation IP, vous pouvez également encapsuler une fonction distincte pour obtenir des informations de localisation.

Ce qui précède représente l'intégralité du contenu de cet article. J'espère qu'il sera utile à l'étude de chacun. Pour plus de contenu connexe, veuillez faire attention au site Web PHP chinois !

Recommandations associées :

À propos de la méthode de table de la méthode ThinkPHP CURD

THinkPHP obtient l'adresse IP du client et la requête d'adresse IP Méthode

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn