Maison développement back-end tutoriel php IP来源查询php源代码_PHP

IP来源查询php源代码_PHP

Jun 01, 2016 pm 12:28 PM
if ip return 来源 查询 源代码

P>《追捕》现在已经响当当了,他的成功,在于它的数据库的维护的毅力,

很多软件都在用它的数据,有些改了名字,变成xxx.dat了,嗬嗬,我觉得不太可取,有点儿不地道的感觉。

我的代码也用到了他,改不改名字无所谓了,关键尊重人家的劳动就好了。

 

在网页上增加一个段简单的代码,就可以显示来访者的地点。

还可以在自己的网站里面写一个个性化的日志,记录ip也记录地点。

效果可以查看 www.fogsun.com 的左边下角.

/**********************************************************************
*                      IP 来源追踪 Ver 1.1a
*              作者 耙子 pazee@21cn.com  http://www.fogsun.com
*                          2002/08/10
*
* 程序中的数据库来自《追捕》,请把追捕中wry.dll 拷贝到函数当前目录。
* 追捕的数据库是个的dbf文件,只不过它的扩展名字变成了dll。
* 2000年我在一个偶然的机会发现了他的dll的真实格式,后来的很多文章也提到了此格式,
* 《追捕》的数据文件目前应用非常广泛,很多查IP来源程序的基本都用到了他的数据库。
* 比如有个去广告,能显示IP来源的QQ就使用了他。
* 2001年初写过一个php的函数,但是需要php的dbf模块支持,很多网站并不提供此模块。
* 现在的版本采用二进制的文件读写,不依赖php的dbf的支持了,没有用到
* 任何shell命令.
* 由于数据文件本身是有序的,所以非常方便的采用了折半查找的算法,
* 速度很快,目前的20020325版本的数据库,大约有记录28905条,最多比较14次。
*
* 在此感谢《追捕》作者“冯志宏”
* 有任何问题请于我联系,谢谢! pazee@21cn.com 
*
*
* 声明:
* 你可以随意传播、复制、修改此程序,但是请保留此段文字。
* 代码请勿用在商业软件上、请勿用在不正当的地方(这是《追捕》的要求),
*                       再次表示谢谢。
***********************************************************************/

// define path of wry.dll
define("DBFILENAME", "wry.dll"); 


class TRec
{
    var $StartIP;
    var $EndIP;
    var $Country;
    var $Local;
}

class TWru
{
    var $ip;
 var $fp;
 var $Rec;
    var $DATAFIELDBEGIN= 0xc2;
    var $RECORDLENGTH;
 
 // Check IP and Format IP
 function FormatIP($ip)
 {
   $ret= ereg("^([0-9]+)\.([0-9]+)\.([0-9]+)\.([0-9]+)$", $ip, $IPSection);
   if ($ret == false)
     return -1; // Invild IP
   $this->ip= ';
   for ($i=1; $i  if ($IPSection[$i] > 255)
    return -1;
  else
    $this->ip.= sprintf("%03.0f", $IPSection[$i]). (($i   return 0;
 }
 
 // read a record from DB  
    function ReadRec($RecNo)
    {
   $this->Seek($RecNo);
      $buf= fread($this->fp, $this->RECORDLENGTH);
      if (strlen($buf) == 0)
      {
        return 1;
      }
      $this->Rec->StartIP= (substr($buf, 0, 17));
      $this->Rec->EndIP= trim(substr($buf, 17, 22));
      $this->Rec->Country= trim(substr($buf, 17+22, 13));
      $this->Rec->Local= trim(substr($buf, 17+22+13, 47));
      return 0;
    }
   
 // Go to Record Number
    function Seek($RecNo)
    {
      return fseek($this->fp, $RecNo * $this->RECORDLENGTH + $this->DATAFIELDBEGIN, SEEK_SET);
    }
   
    // Where_are_you Main Fucntion
 /*********************************************
 * 使用说明
 * 参数:
 *  IP 合法IP地址即可
 *  szLocal 是保存返回的结果字符串的
 * 返回值:
 *   此函数有返回值,可以根据返回值自行处理结果
 *   0: 查找成功
 *  -1: 无效的IP
 *   1: 打开数据库文件失败
 *   2: 数据文件错误(没找到有效记录)
 *   3: 未知 IP
 **********************************************/
 function wru($ip, &$szLocal)
    {
      $this->Rec= new TRec;
      $nRet= 0;
      $this->RECORDLENGTH= 17 + 22 + 13 + 47 + 12 + 1;   
      if ($this->FormatIP($ip) != 0)
      {
        $szLocal= "InvalidIP";
        return -1;
      }
   
      $this->fp= fopen(DBFILENAME, "rb");
      if ($this->fp == NULL) {
        $szLocal= "OpenFileError";
        return 1;
      }
   
      // Get Record Count
      fseek($this->fp, 0, SEEK_END);
      $RecordCount= floor((ftell($this->fp) - $this->DATAFIELDBEGIN) / $this->RECORDLENGTH);
      if ($RecordCount       {
        $szLocal= "FileDataError";
        $nRet= 2;
      }
      else
      {
        $RangB= 0;
        $RangE= $RecordCount;
        // Match ...
        while ($RangB         {
          $RecNo= floor(($RangB + $RangE) / 2);
          $this->ReadRec($RecNo);
          if (strcmp($this->ip, $this->Rec->StartIP) >=0 && strcmp($this->ip, $this->Rec->EndIP)             break;          //Found match record
          if (strcmp($this->ip, $this->Rec->StartIP) > 0)
            $RangB= $RecNo;
          else
            $RangE= $RecNo;
        }
        if (!($RangB         {
          $szLocal= "UnknowLocal!";
          $nRet= 3;
        }
        else
        { // Match Success
          $szLocal= $this->Rec->Country;
          $szLocal.= $this->Rec->Local;
        }
      }
      fclose($this->fp);
      return $nRet;
    }
}

/*******************************************************************
* 变更记录:
* 2002/08/10 完成版本 1.0a
* 2002/08/12 增加FormatIP成员函数,提供了对IP的标准格式化,支持
*   202.96.128.68 这类的写法,类的内部自动转为 202.096.128.068,
*   同时提供了完整的对IP地址的有效检查。规则是4个整数部分均不超
*   过255的自然数。
* ********************************************************************/

?>


  // Test Code.
  $wru= new TWru;
  $szResult="";
  $ip= "202.96.134.133";
  //  $ip= $REMOTE_ADDR;
  $wru->wru($ip, $szResult);
  echo $ip."
";
  echo $szResult;
//---------------------------------------------------------------------------
?>

 

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

Article chaud

Repo: Comment relancer ses coéquipiers
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
Combien de temps faut-il pour battre Split Fiction?
3 Il y a quelques semaines By DDD
Hello Kitty Island Adventure: Comment obtenir des graines géantes
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
1 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌

Article chaud

Repo: Comment relancer ses coéquipiers
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
Combien de temps faut-il pour battre Split Fiction?
3 Il y a quelques semaines By DDD
Hello Kitty Island Adventure: Comment obtenir des graines géantes
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
1 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌

Tags d'article chaud

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Tutoriel sur la mise à jour de la version curl sous Linux ! Tutoriel sur la mise à jour de la version curl sous Linux ! Mar 07, 2024 am 08:30 AM

Tutoriel sur la mise à jour de la version curl sous Linux !

Comment écrire if en langage C pour juger plusieurs conditions Comment écrire if en langage C pour juger plusieurs conditions Mar 25, 2024 pm 03:24 PM

Comment écrire if en langage C pour juger plusieurs conditions

Comment vérifier vos diplômes universitaires sur Xuexin.com Comment vérifier vos diplômes universitaires sur Xuexin.com Mar 28, 2024 pm 04:31 PM

Comment vérifier vos diplômes universitaires sur Xuexin.com

12306 Comment vérifier l'historique des enregistrements d'achat de billets Comment vérifier l'historique des enregistrements d'achat de billets 12306 Comment vérifier l'historique des enregistrements d'achat de billets Comment vérifier l'historique des enregistrements d'achat de billets Mar 28, 2024 pm 03:11 PM

12306 Comment vérifier l'historique des enregistrements d'achat de billets Comment vérifier l'historique des enregistrements d'achat de billets

Comment vérifier la date d'activation sur le téléphone mobile Apple Comment vérifier la date d'activation sur le téléphone mobile Apple Mar 08, 2024 pm 04:07 PM

Comment vérifier la date d'activation sur le téléphone mobile Apple

Comment utiliser Oracle pour demander si une table est verrouillée ? Comment utiliser Oracle pour demander si une table est verrouillée ? Mar 06, 2024 am 11:54 AM

Comment utiliser Oracle pour demander si une table est verrouillée ?

Analyse du chemin de stockage du code source du noyau Linux Analyse du chemin de stockage du code source du noyau Linux Mar 14, 2024 am 11:45 AM

Analyse du chemin de stockage du code source du noyau Linux

Comparaison des similitudes et des différences entre MySQL et PL/SQL Comparaison des similitudes et des différences entre MySQL et PL/SQL Mar 16, 2024 am 11:15 AM

Comparaison des similitudes et des différences entre MySQL et PL/SQL

See all articles