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

不言
Libérer: 2023-04-01 14:10:02
original
3172 Les gens l'ont consulté

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();
Copier après la connexion

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);
Copier après la connexion

Les résultats renvoyés peuvent ressembler à :

2130706433
Copier après la connexion

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地址所在的位置
Copier après la connexion

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

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

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'];
Copier après la connexion

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地址库文件名
Copier après la connexion

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']);
Copier après la connexion

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();
Copier après la connexion

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);
Copier après la connexion

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!

Étiquettes associées:
source:php.cn
Déclaration de ce site Web
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
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal