亚洲韩日午夜视频,欧美日韩在线精品一区二区三区,韩国超清无码一区二区三区,亚洲国产成人影院播放,久草新在线,在线看片AV色

您好,歡迎來到思海網絡,我們將竭誠為您提供優質的服務! 誠征網絡推廣 | 網站備案 | 幫助中心 | 軟件下載 | 購買流程 | 付款方式 | 聯系我們 [ 會員登錄/注冊 ]
促銷推廣
客服中心
業務咨詢
有事點擊這里…  531199185
有事點擊這里…  61352289
點擊這里給我發消息  81721488
有事點擊這里…  376585780
有事點擊這里…  872642803
有事點擊這里…  459248018
有事點擊這里…  61352288
有事點擊這里…  380791050
技術支持
有事點擊這里…  714236853
有事點擊這里…  719304487
有事點擊這里…  1208894568
有事點擊這里…  61352289
在線客服
有事點擊這里…  531199185
有事點擊這里…  61352288
有事點擊這里…  983054746
有事點擊這里…  893984210
當前位置:首頁 >> 技術文章 >> 文章瀏覽
技術文章

PHP:根據IP地址獲取所在城市

添加時間:2014-1-6 17:45:35  添加: 思海網絡 

  文件目錄:

  ipLocation

  -----qqwry

  ----------QQWry.Dat

  -----ipCity.class.php

  ipCity.class.php文件代碼:

   <?php

  class ipCity {

  /**

  * 根據ip地址獲取對應所在城市

  * @param type $userip 用戶IP地址

  * @return string

  */

  public function getCity( $userip, $dat_path = '' ) {

  //IP數據庫路徑,這里用的是QQ IP數據庫 20110405 純真版

  empty( $dat_path ) && $dat_path = FCPATH . 'plugin/ipLocation/qqwry/QQWry.Dat';

  //判斷IP地址是否有效

  if ( preg_match( "/^([0-9]{1,3}.){3}[0-9]{1,3}$/", $userip ) == 0 ) {

  return 'IP Address Invalid';

  }

  //打開IP數據庫

  if ( !$fd = @fopen( $dat_path, 'rb' ) ) {

  return 'IP data file not exists or access denied';

  }

  //explode函數分解IP地址,運算得出整數形結果

  $userip = explode( '.', $userip );

  $useripNum = $userip[0] * 16777216 + $userip[1] * 65536 + $userip[2] * 256 + $userip[3];

  //獲取IP地址索引開始和結束位置

  $DataBegin = fread( $fd, 4 );

  $DataEnd = fread( $fd, 4 );

  $useripbegin = implode( '', unpack( 'L', $DataBegin ) );

  if ( $useripbegin < 0 )

  $useripbegin += pow( 2, 32 );

  $useripend = implode( '', unpack( 'L', $DataEnd ) );

  if ( $useripend < 0 )

  $useripend += pow( 2, 32 );

  $useripAllNum = ($useripend - $useripbegin) / 7 + 1;

  $BeginNum = 0;

  $EndNum = $useripAllNum;

  //使用二分查找法從索引記錄中搜索匹配的IP地址記錄

  while ( $userip1num > $useripNum || $userip2num < $useripNum ) {

  $Middle = intval( ($EndNum + $BeginNum) / 2 );

  //偏移指針到索引位置讀取4個字節

  fseek( $fd, $useripbegin + 7 * $Middle );

  $useripData1 = fread( $fd, 4 );

  if ( strlen( $useripData1 ) < 4 ) {

  fclose( $fd );

  return 'File Error';

  }

  //提取出來的數據轉換成長整形,如果數據是負數則加上2的32次冪

  $userip1num = implode( '', unpack( 'L', $useripData1 ) );

  if ( $userip1num < 0 )

  $userip1num += pow( 2, 32 );

  //提取的長整型數大于我們IP地址則修改結束位置進行下一次循環

  if ( $userip1num > $useripNum ) {

  $EndNum = $Middle;

  continue;

  }

  //取完上一個索引后取下一個索引

  $DataSeek = fread( $fd, 3 );

  if ( strlen( $DataSeek ) < 3 ) {

  fclose( $fd );

  return 'File Error';

  }

  $DataSeek = implode( '', unpack( 'L', $DataSeek . chr( 0 ) ) );

  fseek( $fd, $DataSeek );

  $useripData2 = fread( $fd, 4 );

  if ( strlen( $useripData2 ) < 4 ) {

  fclose( $fd );

  return 'File Error';

  }

  $userip2num = implode( '', unpack( 'L', $useripData2 ) );

  if ( $userip2num < 0 )

  $userip2num += pow( 2, 32 );

  //找不到IP地址對應城市

  if ( $userip2num < $useripNum ) {

  if ( $Middle == $BeginNum ) {

  fclose( $fd );

  return 'No Data';

  }

  $BeginNum = $Middle;

  }

  }

  $useripFlag = fread( $fd, 1 );

  if ( $useripFlag == chr( 1 ) ) {

  $useripSeek = fread( $fd, 3 );

  if ( strlen( $useripSeek ) < 3 ) {

  fclose( $fd );

  return 'System Error';

  }

  $useripSeek = implode( '', unpack( 'L', $useripSeek . chr( 0 ) ) );

  fseek( $fd, $useripSeek );

  $useripFlag = fread( $fd, 1 );

  }

 

  if ( $useripFlag == chr( 2 ) ) {

  $AddrSeek = fread( $fd, 3 );

  if ( strlen( $AddrSeek ) < 3 ) {

  fclose( $fd );

  return 'System Error';

  }

  $useripFlag = fread( $fd, 1 );

  if ( $useripFlag == 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 ) )

  $useripAddr2 .= $char;

  $AddrSeek = implode( '', unpack( 'L', $AddrSeek . chr( 0 ) ) );

  fseek( $fd, $AddrSeek );

  while ( ($char = fread( $fd, 1 )) != chr( 0 ) )

  $useripAddr1 .= $char;

  } else {

  fseek( $fd, -1, SEEK_CUR );

  while ( ($char = fread( $fd, 1 )) != chr( 0 ) )

  $useripAddr1 .= $char;

  $useripFlag = fread( $fd, 1 );

  if ( $useripFlag == 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 ) ) {

  $useripAddr2 .= $char;

  }

  }

  fclose( $fd );

  //返回IP地址對應的城市結果

  if ( preg_match( '/http/i', $useripAddr2 ) ) {

  $useripAddr2 = '';

  }

  $useripaddr = "$useripAddr1 $useripAddr2";

  $useripaddr = preg_replace( '/CZ88.Net/is', '', $useripaddr );

  $useripaddr = preg_replace( '/^s*/is', '', $useripaddr );

  $useripaddr = preg_replace( '/s*$/is', '', $useripaddr );

  if ( preg_match( '/http/i', $useripaddr ) || $useripaddr == '' ) {

  $useripaddr = 'No Data';

  } elseif ( !$this->is_utf8( $useripaddr ) ) {

  $useripaddr = iconv( 'GBK', 'UTF-8', $useripaddr );

  }

  return $useripaddr;

  }

  /**

  * 判斷是否我utf-8編碼的字符串

  * @param type $string

  * @return boolean

  */

  private function is_utf8( $string ) {

  if ( preg_match( "/^([" . chr( 228 ) . "-" . chr( 233 ) . "]{1}[" . chr( 128 ) . "-" . chr( 191 ) . "]{1}[" . chr( 128 ) . "-" . chr( 191 ) . "]{1}){1}/", $string ) == true || preg_match( "/([" . chr( 228 ) . "-" . chr( 233 ) . "]{1}[" . chr( 128 ) . "-" . chr( 191 ) . "]{1}[" . chr( 128 ) . "-" . chr( 191 ) . "]{1}){1}$/", $string ) == true || preg_match( "/([" . chr( 228 ) . "-" . chr( 233 ) . "]{1}[" . chr( 128 ) . "-" . chr( 191 ) . "]{1}[" . chr( 128 ) . "-" . chr( 191 ) . "]{1}){2,}/", $string ) == true ) {

  return true;

  } else {

  return false;

  }

  }

  }

  QQWry.Dat文件可以在百度上搜索或者需要的發你郵箱來,我通過郵箱發給你。

  使用演示:

  ?

  1

  2

  3

  4 include FCPATH . 'plugin/ipLocation/ipCity.class.php';

  $city = new ipCity();

  $addr = $city->getCity( '172.0.0.1' );

  echo $addr; // echo 本地地址

關鍵字:IP地址、文件目錄、PHP

分享到:

頂部 】 【 關閉
版權所有:佛山思海電腦網絡有限公司 ©1998-2024 All Rights Reserved.
聯系電話:(0757)22630313、22633833
中華人民共和國增值電信業務經營許可證: 粵B1.B2-20030321 備案號:粵B2-20030321-1
網站公安備案編號:44060602000007 交互式欄目專項備案編號:200303DD003  
察察 工商 網安 舉報有獎  警警  手機打開網站