PHP利用纯真IP数据库在本地实现IP地址信息查询

Wesley13
• 阅读 647

封装IP函数

<?php
class cls_ipAddress{
    private $fp;
    private $firstip;
    private $lastip;
    private $totalip;

    public function __construct($filename="qqwry.dat"){
        $this->fp=0;
        if(($this->fp=@fopen($filename,"rb"))!==false){
            $this->firstip=$this->getlong();
            $this->lastip=$this->getlong();
            $this->totalip=($this->lastip-$this->firstip)/7;
            register_shutdown_function(array(&$this,"__destruct"));
        }
    }

    public function __destruct(){
        if($this->fp){
            @fclose($this->fp);
        }
        $this->fp=0;
    }

    private function getlong(){
        $result=unpack("Vlong",fread($this->fp,4));
        return $result["long"];
    }

    private function getlong3(){
        $result=unpack("Vlong",fread($this->fp,3).chr(0));
        return $result["long"];
    }

    private function packip($ip){
        return pack("N",intval(ip2long($ip)));
    }

    private function getstring($data=""){
        $char=fread($this->fp,1);
        while(ord($char)>0){
            $data.=$char;
            $char=fread($this->fp,1);
        }
        return $data;
    }

    private function getarea(){
        $byte=fread($this->fp,1);
        switch(ord($byte)){
        case 0:
            $operators="";
        break;
        case 1:
        case 2:
            fseek($this->fp,$this->getlong3());
            $operators=$this->getstring();
        break;
        default:
            $operators=$this->getstring($byte);
        break;}
        return $operators;
    }

    public function getlocation($ip){
        if(!$this->fp){return null;}
        $location["ip"]=gethostbyname($ip);
        $ip=$this->packip($location["ip"]);
        $l=0;
        $u=$this->totalip;
        $findip=$this->lastip;
        while($l<=$u){
            $i=floor(($l+$u)/2);
            fseek($this->fp,$this->firstip+$i*7);
            $startip=strrev(fread($this->fp,4));
            if($ip<$startip){
                $u=$i-1;
            }else{
                fseek($this->fp,$this->getlong3());
                $endip=strrev(fread($this->fp,4));
                if($ip>$endip){
                    $l=$i+1;
                }else{
                    $findip=$this->firstip+$i*7;
                    break;
                }
            }
        }
        fseek($this->fp,$findip);
        $location["startip"]=long2ip($this->getlong());
        $offset=$this->getlong3();
        fseek($this->fp,$offset);
        $location["endip"]=long2ip($this->getlong());
        $byte=fread($this->fp,1);
        switch(ord($byte)){
        case 1:
            $countryOffset=$this->getlong3();
            fseek($this->fp,$countryOffset);
            $byte=fread($this->fp,1);
            switch(ord($byte)){
            case 2:
                fseek($this->fp,$this->getlong3());
                $location["area"]=$this->getstring();
                fseek($this->fp,$countryOffset+4);
                $location["operators"]=$this->getarea();
            break;
            default:
                $location["area"]=$this->getstring($byte);
                $location["operators"]=$this->getarea();
            break;}
        break;
        case 2:
            fseek($this->fp,$this->getlong3());
            $location["area"]=$this->getstring();
            fseek($this->fp,$offset+8);
            $location["operators"]=$this->getarea();
        break;
        default:
            $location["area"]=$this->getstring($byte);
            $location["operators"]=$this->getarea();
        break;}
        if($location["area"]=="CZ88.NET"){
            $location["area"]="未知";
        }
        if($location["operators"]=="CZ88.NET"){
            $location["operators"]="未知";
        }
        return $location;
    }
}
?>

调用IP函数

<?php
$ip="220.186.136.207";
$setip=new cls_ipAddress("qqwry.dat");
$location=$setip->getlocation($ip);
print_r($location);
?>
点赞
收藏
评论区
推荐文章
blmius blmius
3年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录问题用navicat导入数据时,报错:原因这是因为当前的MySQL不支持datetime为0的情况。解决修改sql\mode:sql\mode:SQLMode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。全局s
皕杰报表之UUID
​在我们用皕杰报表工具设计填报报表时,如何在新增行里自动增加id呢?能新增整数排序id吗?目前可以在新增行里自动增加id,但只能用uuid函数增加UUID编码,不能新增整数排序id。uuid函数说明:获取一个UUID,可以在填报表中用来创建数据ID语法:uuid()或uuid(sep)参数说明:sep布尔值,生成的uuid中是否包含分隔符'',缺省为
待兔 待兔
4个月前
手写Java HashMap源码
HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程22
Jacquelyn38 Jacquelyn38
3年前
2020年前端实用代码段,为你的工作保驾护航
有空的时候,自己总结了几个代码段,在开发中也经常使用,谢谢。1、使用解构获取json数据let jsonData  id: 1,status: "OK",data: 'a', 'b';let  id, status, data: number   jsonData;console.log(id, status, number )
Stella981 Stella981
3年前
KVM调整cpu和内存
一.修改kvm虚拟机的配置1、virsheditcentos7找到“memory”和“vcpu”标签,将<namecentos7</name<uuid2220a6d1a36a4fbb8523e078b3dfe795</uuid
Wesley13 Wesley13
3年前
PHP创建多级树型结构
<!lang:php<?php$areaarray(array('id'1,'pid'0,'name''中国'),array('id'5,'pid'0,'name''美国'),array('id'2,'pid'1,'name''吉林'),array('id'4,'pid'2,'n
Stella981 Stella981
3年前
Android蓝牙连接汽车OBD设备
//设备连接public class BluetoothConnect implements Runnable {    private static final UUID CONNECT_UUID  UUID.fromString("0000110100001000800000805F9B34FB");
Stella981 Stella981
3年前
Django中Admin中的一些参数配置
设置在列表中显示的字段,id为django模型默认的主键list_display('id','name','sex','profession','email','qq','phone','status','create_time')设置在列表可编辑字段list_editable
Wesley13 Wesley13
3年前
MySQL部分从库上面因为大量的临时表tmp_table造成慢查询
背景描述Time:20190124T00:08:14.70572408:00User@Host:@Id:Schema:sentrymetaLast_errno:0Killed:0Query_time:0.315758Lock_
Python进阶者 Python进阶者
10个月前
Excel中这日期老是出来00:00:00,怎么用Pandas把这个去除
大家好,我是皮皮。一、前言前几天在Python白银交流群【上海新年人】问了一个Pandas数据筛选的问题。问题如下:这日期老是出来00:00:00,怎么把这个去除。二、实现过程后来【论草莓如何成为冻干莓】给了一个思路和代码如下:pd.toexcel之前把这