php读取纯真ip数据库的例子_PHP教程
代码:
<?<span php </span><span /*</span><span -------------------------------------------------- ip2address [qqwry.dat] --------------------------------------------------</span><span */</span> <span class</span><span ip { </span><span var</span> <span $fh</span>; <span //</span><span IP数据库文件句柄</span> <span var</span> <span $first</span>; <span //</span><span 第一条索引</span> <span var</span> <span $last</span>; <span //</span><span 最后一条索引</span> <span var</span> <span $total</span>; <span //</span><span 索引总数 //构造函数</span> <span function</span><span __construct() { </span><span $this</span>->fh = <span fopen</span>('qqwry.dat', 'rb'); <span //</span><span qqwry.dat文件</span> <span $this</span>->first = <span $this</span>-><span getLong4(); </span><span $this</span>->last = <span $this</span>-><span getLong4(); </span><span $this</span>->total = (<span $this</span>->last - <span $this</span>->first) / 7; <span //</span><span 每条索引7字节</span> <span } </span><span //</span><span 检查IP合法性</span> <span function</span> checkIp(<span $ip</span><span ) { </span><span $arr</span> = <span explode</span>('.',<span $ip</span><span ); </span><span if</span>(<span count</span>(<span $arr</span>) !=4<span ) { </span><span return</span> <span false</span><span ; } </span><span else</span><span { </span><span for</span> (<span $i</span>=0; <span $i</span> < 4; <span $i</span>++<span ) { </span><span if</span> (<span $arr</span>[<span $i</span>] <'0' || <span $arr</span>[<span $i</span>] > '255'<span ) { </span><span return</span> <span false</span><span ; } } </span><span //</span><span 脚本学堂 www.jbxue.com</span> <span } </span><span return</span> <span true</span><span ; } </span><span function</span><span getLong4() { </span><span //</span><span 读取little-endian编码的4个字节转化为长整型数</span> <span $result</span> = <span unpack</span>('Vlong', <span fread</span>(<span $this</span>->fh, 4<span )); </span><span return</span> <span $result</span>['long'<span ]; } </span><span function</span><span getLong3() { </span><span //</span><span 读取little-endian编码的3个字节转化为长整型数</span> <span $result</span> = <span unpack</span>('Vlong', <span fread</span>(<span $this</span>->fh, 3).<span chr</span>(0<span )); </span><span return</span> <span $result</span>['long'<span ]; } </span><span //</span><span 查询信息</span> <span function</span> getInfo(<span $data</span> = ""<span ) { </span><span $char</span> = <span fread</span>(<span $this</span>->fh, 1<span ); </span><span while</span> (<span ord</span>(<span $char</span>) != 0) { <span //</span><span 国家地区信息以0结束</span> <span $data</span> .= <span $char</span><span ; </span><span $char</span> = <span fread</span>(<span $this</span>->fh, 1<span ); } </span><span return</span> <span $data</span><span ; } </span><span //</span><span 查询地区信息</span> <span function</span><span getArea() { </span><span $byte</span> = <span fread</span>(<span $this</span>->fh, 1); <span //</span><span 标志字节</span> <span switch</span> (<span ord</span>(<span $byte</span><span )) { </span><span case</span> 0: <span $area</span> = ''; <span break</span>; <span //</span><span 没有地区信息</span> <span case</span> 1: <span //</span><span 地区被重定向</span> <span fseek</span>(<span $this</span>->fh, <span $this</span>-><span getLong3()); </span><span $area</span> = <span $this</span>->getInfo(); <span break</span><span ; </span><span case</span> 2: <span //</span><span 地区被重定向</span> <span fseek</span>(<span $this</span>->fh, <span $this</span>-><span getLong3()); </span><span $area</span> = <span $this</span>->getInfo(); <span break</span><span ; </span><span default</span>: <span $area</span> = <span $this</span>->getInfo(<span $byte</span>); <span break</span>; <span //</span><span 地区没有被重定向</span> <span } </span><span return</span> <span $area</span><span ; } </span><span function</span> ip2addr(<span $ip</span><span ) { </span><span if</span>(!<span $this</span> -> checkIp(<span $ip</span><span )){ </span><span return</span> <span false</span><span ; } </span><span $ip</span> = <span pack</span>('N', <span intval</span>(<span ip2long</span>(<span $ip</span><span ))); </span><span //</span><span 二分查找</span> <span $l</span> = 0<span ; </span><span $r</span> = <span $this</span>-><span total; </span><span while</span>(<span $l</span> <= <span $r</span><span ) { </span><span $m</span> = <span floor</span>((<span $l</span> + <span $r</span>) / 2); <span //</span><span 计算中间索引</span> <span fseek</span>(<span $this</span>->fh, <span $this</span>->first + <span $m</span> * 7<span ); </span><span $beginip</span> = <span strrev</span>(<span fread</span>(<span $this</span>->fh, 4)); <span //</span><span 中间索引的开始IP地址</span> <span fseek</span>(<span $this</span>->fh, <span $this</span>-><span getLong3()); </span><span $endip</span> = <span strrev</span>(<span fread</span>(<span $this</span>->fh, 4)); <span //</span><span 中间索引的结束IP地址</span> <span if</span> (<span $ip</span> < <span $beginip</span>) { <span //</span><span 用户的IP小于中间索引的开始IP地址时</span> <span $r</span> = <span $m</span> - 1<span ; } </span><span else</span><span { </span><span if</span> (<span $ip</span> > <span $endip</span>) { <span //</span><span 用户的IP大于中间索引的结束IP地址时</span> <span $l</span> = <span $m</span> + 1<span ; } </span><span else</span> { <span //</span><span 用户IP在中间索引的IP范围内时</span> <span $findip</span> = <span $this</span>->first + <span $m</span> * 7<span ; </span><span break</span><span ; } } } </span><span //</span><span 查询国家地区信息</span> <span fseek</span>(<span $this</span>->fh, <span $findip</span><span ); </span><span $location</span>['beginip'] = <span long2ip</span>(<span $this</span>->getLong4()); <span //</span><span 用户IP所在范围的开始地址</span> <span $offset</span> = <span $this</span>-><span getlong3(); </span><span fseek</span>(<span $this</span>->fh, <span $offset</span><span ); </span><span $location</span>['endip'] = <span long2ip</span>(<span $this</span>->getLong4()); <span //</span><span 用户IP所在范围的结束地址</span> <span $byte</span> = <span fread</span>(<span $this</span>->fh, 1); <span //</span><span 标志字节</span> <span switch</span> (<span ord</span>(<span $byte</span><span )) { </span><span case</span> 1: <span //</span><span 国家和区域信息都被重定向</span> <span $countryOffset</span> = <span $this</span>->getLong3(); <span //</span><span 重定向地址</span> <span fseek</span>(<span $this</span>->fh, <span $countryOffset</span><span ); </span><span $byte</span> = <span fread</span>(<span $this</span>->fh, 1); <span //</span><span 标志字节</span> <span switch</span> (<span ord</span>(<span $byte</span><span )) { </span><span case</span> 2: <span //</span><span 国家信息被二次重定向</span> <span fseek</span>(<span $this</span>->fh, <span $this</span>-><span getLong3()); </span><span $location</span>['country'] = <span $this</span>-><span getInfo(); </span><span fseek</span>(<span $this</span>->fh, <span $countryOffset</span> + 4<span ); </span><span $location</span>['area'] = <span $this</span>-><span getArea(); </span><span break</span><span ; </span><span default</span>: <span //</span><span 国家信息没有被二次重定向</span> <span $location</span>['country'] = <span $this</span>->getInfo(<span $byte</span><span ); </span><span $location</span>['area'] = <span $this</span>-><span getArea(); </span><span break</span><span ; } </span><span break</span><span ; </span><span case</span> 2: <span //</span><span 国家信息被重定向</span> <span fseek</span>(<span $this</span>->fh, <span $this</span>-><span getLong3()); </span><span $location</span>['country'] = <span $this</span>-><span getInfo(); </span><span fseek</span>(<span $this</span>->fh, <span $offset</span> + 8<span ); </span><span $location</span>['area'] = <span $this</span>-><span getArea(); </span><span break</span><span ; </span><span default</span>: <span //</span><span 国家信息没有被重定向</span> <span $location</span>['country'] = <span $this</span>->getInfo(<span $byte</span><span ); </span><span $location</span>['area'] = <span $this</span>-><span getArea(); </span><span break</span><span ; } </span><span //</span><span gb2312 to utf-8(去除无信息时显示的CZ88.NET)</span> <span foreach</span> (<span $location</span> <span as</span> <span $k</span> => <span $v</span><span ) { </span><span $location</span>[<span $k</span>] = <span str_replace</span>('CZ88.NET','',<span iconv</span>('gb2312', 'utf-8', <span $v</span><span )); } </span><span return</span> <span $location</span><span ; } </span><span //</span><span 析构函数</span> <span function</span><span __destruct() { </span><span fclose</span>(<span $this</span>-><span fh); } } </span><span $ip</span> = <span new</span><span ip(); </span><span $addr</span> = <span $ip</span> -> ip2addr('IP地址'<span ); </span><span print_r</span>(<span $addr</span><span ); </span>?>

Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

AI Hentai Generator
Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

Heiße Werkzeuge

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Heiße Themen



Die Kombination von Vue.js und ASP.NET liefert Tipps und Vorschläge zur Leistungsoptimierung und Erweiterung von Webanwendungen. Mit der rasanten Entwicklung von Webanwendungen ist die Leistungsoptimierung zu einer unverzichtbaren und wichtigen Aufgabe für Entwickler geworden. Als beliebtes Front-End-Framework kann Vue.js in Kombination mit ASP.NET uns dabei helfen, eine bessere Leistungsoptimierung und -erweiterung zu erreichen. In diesem Artikel werden einige Tipps und Vorschläge vorgestellt sowie einige Codebeispiele bereitgestellt. 1. HTTP-Anfragen reduzieren Die Anzahl der HTTP-Anfragen wirkt sich direkt auf die Ladegeschwindigkeit von Webanwendungen aus. passieren

Übersetzer | Rezensiert von Chen Jun | Entsprechende integrierte Entwicklungsumgebungen (IDEs) wie Eclipse und Visual Studio können Programmierung, Entwicklung, Dokumentation, Konstruktion, Test, Bereitstellung und andere Schritte in einen vollständigen Softwareentwicklungslebenszyklus (SDLC) integrieren und so die Arbeit der Entwickler verbessern. In den letzten Jahren haben beliebte Cloud-Computing- und DevSecOps-Automatisierungstools die umfassenden Fähigkeiten von Entwicklern verbessert und es für mehr Unternehmen einfacher gemacht, Softwareanwendungen zu entwickeln, bereitzustellen und zu warten. Heute ist generative KI die Entwicklung der nächsten Generation

Wie verwende und optimiere ich den MySQL-Verbindungspool in ASP.NET-Programmen richtig? Einführung: MySQL ist ein weit verbreitetes Datenbankverwaltungssystem, das sich durch hohe Leistung, Zuverlässigkeit und Benutzerfreundlichkeit auszeichnet. Bei der ASP.NET-Entwicklung ist die Verwendung einer MySQL-Datenbank zur Datenspeicherung eine häufige Anforderung. Um die Effizienz und Leistung von Datenbankverbindungen zu verbessern, müssen wir den MySQL-Verbindungspool korrekt verwenden und optimieren. In diesem Artikel erfahren Sie, wie Sie den MySQL-Verbindungspool in ASP.NET-Programmen korrekt verwenden und optimieren.

Wie kann ich im ASP.NET-Programm erneut eine Verbindung zu MySQL herstellen? In der ASP.NET-Entwicklung wird häufig die MySQL-Datenbank verwendet. Aus Gründen des Netzwerks oder des Datenbankservers kann es jedoch manchmal zu Unterbrechungen oder einer Zeitüberschreitung der Datenbankverbindung kommen. In diesem Fall müssen wir die Verbindung wiederherstellen, nachdem die Verbindung getrennt wurde, um die Stabilität und Zuverlässigkeit des Programms sicherzustellen. In diesem Artikel erfahren Sie, wie Sie MySQL-Verbindungen in ASP.NET-Programmen wiederherstellen. Um zunächst auf die erforderlichen Namespaces zu verweisen, verweisen Sie diese am Anfang der Codedatei

Die Kombination von Vue.js und ASP.NET ermöglicht die Entwicklung und Bereitstellung von Anwendungen auf Unternehmensebene. Im heutigen sich schnell entwickelnden Bereich der Internettechnologie wird die Entwicklung und Bereitstellung von Anwendungen auf Unternehmensebene immer wichtiger. Vue.js und ASP.NET sind zwei Technologien, die in der Front-End- und Back-End-Entwicklung weit verbreitet sind. Ihre Kombination kann viele Vorteile für die Entwicklung und Bereitstellung von Anwendungen auf Unternehmensebene bringen. In diesem Artikel wird anhand von Codebeispielen erläutert, wie Sie mit Vue.js und ASP.NET Anwendungen auf Unternehmensebene entwickeln und bereitstellen. Zuerst müssen wir installieren

Wie konfiguriere und verwende ich den MySQL-Verbindungspool im ASP.NET-Programm richtig? Mit der Entwicklung des Internets und der Zunahme des Datenvolumens steigt auch der Bedarf an Datenbankzugängen und -verbindungen. Um die Leistung und Stabilität der Datenbank zu verbessern, ist Verbindungspooling zu einer wesentlichen Technologie geworden. In diesem Artikel wird hauptsächlich die korrekte Konfiguration und Verwendung des MySQL-Verbindungspools in ASP.NET-Programmen vorgestellt, um die Effizienz und Antwortgeschwindigkeit der Datenbank zu verbessern. 1. Das Konzept und die Funktion des Verbindungspoolings ist eine Technologie, die Datenbankverbindungen wiederverwendet.

Wie kann die Transaktionsleistung des MySQL-Verbindungspools in ASP.NET-Programmen richtig genutzt und optimiert werden? In ASP.NET-Programmen sind Datenbanktransaktionen ein sehr wichtiger Bestandteil. Transaktionen stellen die Konsistenz und Integrität der Datenbank sicher und sorgen gleichzeitig für eine bessere Leistung. Bei der Verwendung einer MySQL-Datenbank ist es wichtig, Verbindungspools zu verwenden, um Verbindungsressourcen zu verwalten und die Leistung zu optimieren. Lassen Sie uns zunächst kurz das Konzept des MySQL-Verbindungspools verstehen. Der Verbindungspool ist ein Pufferpool einer Gruppe von Verbindungen, indem eine bestimmte Anzahl von Verbindungen vorab initialisiert wird

Zu den integrierten Objekten in ASP.NET gehören „Request“, „Response“, „Session“, „Server“, „Application“, „HttpContext“, „Cache“, „Trace“, „Cookie“ und „Server.MapPath“: 1. Anfrage, Angabe der vom Client ausgegebenen HTTP-Anfrage; 2. Antwort: Angabe der vom Webserver zurückgegebenen HTTP-Antwort Kunde usw.
