PHP调用纯真IP数据库返回具体地址

PHP调用纯真IP数据库返回具体地址

    function convertip($ip) {   
      $ip1num = 0;  
      $ip2num = 0;  
      $ipAddr1 ="";  
      $ipAddr2 ="";  
      $dat_path = './QQWry.Dat';          
      if(!preg_match("/^\d{1,3}\.\d{1,3}\.\d{1,3}\.\d{1,3}$/", $ip)) {   
        return 'IP Address Error';   
      }    
      if(!$fd = @fopen($dat_path, 'rb')){   
        return 'IP date file not exists or access denied';   
      }    
      $ip = explode('.', $ip);   
      $ipNum = $ip[0] * 16777216 + $ip[1] * 65536 + $ip[2] * 256 + $ip[3];    
      $DataBegin = fread($fd, 4);   
      $DataEnd = fread($fd, 4);   
      $ipbegin = implode('', unpack('L', $DataBegin));   
      if($ipbegin < 0) $ipbegin += pow(2, 32);   
        $ipend = implode('', unpack('L', $DataEnd));   
      if($ipend < 0) $ipend += pow(2, 32);   
        $ipAllNum = ($ipend - $ipbegin) / 7 + 1;   
      $BeginNum = 0;   
      $EndNum = $ipAllNum;    
      while($ip1num>$ipNum || $ip2num<$ipNum) {   
        $Middle= intval(($EndNum + $BeginNum) / 2);   
        fseek($fd, $ipbegin + 7 * $Middle);   
        $ipData1 = fread($fd, 4);   
        if(strlen($ipData1) < 4) {   
          fclose($fd);   
          return 'System Error';   
        }  
        $ip1num = implode('', unpack('L', $ipData1));   
        if($ip1num < 0) $ip1num += pow(2, 32);   
      
        if($ip1num > $ipNum) {   
          $EndNum = $Middle;   
          continue;   
        }   
        $DataSeek = fread($fd, 3);   
        if(strlen($DataSeek) < 3) {   
          fclose($fd);   
          return 'System Error';   
        }   
        $DataSeek = implode('', unpack('L', $DataSeek.chr(0)));   
        fseek($fd, $DataSeek);   
        $ipData2 = fread($fd, 4);   
        if(strlen($ipData2) < 4) {   
          fclose($fd);   
          return 'System Error';   
        }   
        $ip2num = implode('', unpack('L', $ipData2));   
        if($ip2num < 0) $ip2num += pow(2, 32);    
          if($ip2num < $ipNum) {   
            if($Middle == $BeginNum) {   
              fclose($fd);   
              return 'Unknown';   
            }   
            $BeginNum = $Middle;   
          }   
        }    
        $ipFlag = fread($fd, 1);   
        if($ipFlag == chr(1)) {   
          $ipSeek = fread($fd, 3);   
          if(strlen($ipSeek) < 3) {   
            fclose($fd);   
            return 'System Error';   
          }   
          $ipSeek = implode('', unpack('L', $ipSeek.chr(0)));   
          fseek($fd, $ipSeek);   
          $ipFlag = fread($fd, 1);   
        }   
        if($ipFlag == chr(2)) {   
          $AddrSeek = fread($fd, 3);   
          if(strlen($AddrSeek) < 3) {   
          fclose($fd);   
          return 'System Error';   
        }   
        $ipFlag = fread($fd, 1);   
        if($ipFlag == chr(2)) {   
          $AddrSeek2 = fread($fd, 3);   
          if(strlen($AddrSeek2) < 3) {   
            fclose($fd);   
            return 'System Error';   
          }   
          $AddrSeek2 = implode('', unpack('L', $AddrSeek2.chr(0)));   
          fseek($fd, $AddrSeek2);   
        } else {   
          fseek($fd, -1, SEEK_CUR);   
        }   
        while(($char = fread($fd, 1)) != chr(0))   
        $ipAddr2 .= $char;   
        $AddrSeek = implode('', unpack('L', $AddrSeek.chr(0)));   
        fseek($fd, $AddrSeek);   
        while(($char = fread($fd, 1)) != chr(0))   
        $ipAddr1 .= $char;   
      } else {   
        fseek($fd, -1, SEEK_CUR);   
        while(($char = fread($fd, 1)) != chr(0))   
        $ipAddr1 .= $char;   
        $ipFlag = fread($fd, 1);   
        if($ipFlag == chr(2)) {   
          $AddrSeek2 = fread($fd, 3);   
          if(strlen($AddrSeek2) < 3) {   
            fclose($fd);   
            return 'System Error';   
          }   
          $AddrSeek2 = implode('', unpack('L', $AddrSeek2.chr(0)));   
          fseek($fd, $AddrSeek2);   
        } else {   
          fseek($fd, -1, SEEK_CUR);   
        }   
        while(($char = fread($fd, 1)) != chr(0)){   
          $ipAddr2 .= $char;   
        }   
      }   
      fclose($fd);    
      if(preg_match('/http/i', $ipAddr2)) {   
        $ipAddr2 = '';   
      }   
      $ipaddr = "$ipAddr1 $ipAddr2";   
      $ipaddr = preg_replace('/CZ88.NET/is', '', $ipaddr);   
      $ipaddr = preg_replace('/^s*/is', '', $ipaddr);   
      $ipaddr = preg_replace('/s*$/is', '', $ipaddr);   
      if(preg_match('/http/i', $ipaddr) || $ipaddr == '') {   
        $ipaddr = 'Unknown';   
      }   
      return $ipaddr;   
    }  

 

只要调用此方法,传入一个正确的IP地址,就能得到纯真IP数据库中相对应的地理位置了

例如:
convertip(202.96.209.5)  

返回的值为:上海市 电信

 
注:写有此方法的文件需和纯真数据库文件(QQWry.Dat)放在同一级目录,否则就需要修改$dat_path的内容。

准备工作:

建议本地IP地址数据库,请到http://www.cz88.net/这个网站下载一个纯真IP数据库,安装完成后,到安装目录里把QQWry.dat文件取出来,这个就是我们想要的IP数据库了,放到你想要目录下。

 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/113445.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 安卓手机如何打开.pdf(1)文件_手机pdf格式怎么使用查找功能

    安卓手机如何打开.pdf(1)文件_手机pdf格式怎么使用查找功能最近在做结算功能,需要上传发票功能,发票有电子和图片发票两种,技术这边有两种方案,一种是上传图片文件,还有一种是上传PDF格式发票文件,但是结算时财务说图片文件上面没有公司盖章,是无效的,于是把方案改为电子发票PDF和纸质发票,刚开始使用的文件管理器搜索手机内的PDF文件,在4.4系统上面打开文件管理器可以过滤掉非.pdf格式文件,在6.0及以上系统没有过滤掉,用的是intent打开u…

    2025年5月23日
    0
  • 矩阵的模的平方matlab,matlab求矩阵、向量的模

    矩阵的模的平方matlab,matlab求矩阵、向量的模求矩阵的模:functioncount=juZhenDeMo(a,b)[r,c]=size(a);%求a的行列[r1,c1]=size(b);%求b的行列count=0;forj=1:r-r1+1%所求的行数中取fori=1:c-c1+1%所有的列数中取d=a(j:j+r1-1,i:i+c1-1);e=double(d==b);if(sum(e(:))==r1*c1)…

    2022年5月14日
    51
  • matlab如何做正交多项式曲线拟合,matlab正交多项式拟合

    matlab如何做正交多项式曲线拟合,matlab正交多项式拟合在实验模态分析中用Matlab实现离散化正交多项式算法[C],马永列;陈章位;胡海清4.在实验模态分析中用Matlab实现离散化正交多项式算法[C],马永列……变换后的条件数上限表如下:拟合次数1=1cond2(A)2<9.93<50.34<435④在实际应用中还可以利用正交多项式求拟合多项式。一种方法是构造离散……..

    2025年5月24日
    0
  • c语言pdb文件,VISUAL c+中的pdb文件及其作用「建议收藏」

    c语言pdb文件,VISUAL c+中的pdb文件及其作用「建议收藏」VISUALc+中的pdb文件及其作用程序数据库(PDB)文件保存着调试和项目状态信息,使用这些信息可以对程序的调试配置进行增量链接。当以/ZI或/Zi(用于C/C++)生成时,将创建一个PDB文件。在VisualC++中,/Fd选项用于命名由编译器创建的PDB文件。当使用向导在VisualStudio中创建项目时,/Fd选项被设置为创建一个名为projec…

    2022年6月2日
    30
  • matlab求解时滞微分方程_matlab延迟环节传递函数

    matlab求解时滞微分方程_matlab延迟环节传递函数具有常时滞的DDERef:时滞微分方程—示例

    2022年9月27日
    0
  • 深度强化学习——DQN「建议收藏」

    DQN(DeepQ-Learning)可谓是深度强化学习(DeepReinforcementLearning)的开山之作,是将深度学习与增强学习结合起来从而实现从感知(Perception)到动作(Action)的端对端(End-to-end)学习的一种全新的算法。

    2022年4月6日
    231

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号