`
xhq6632
  • 浏览: 13477 次
  • 性别: Icon_minigender_1
  • 来自: 成都
社区版块
存档分类
最新评论

发一个用IP得到真实地址的,是网上找的程序修改后的,直接输出utf-8信息。

阅读更多
发一个用IP得到真实地址的,是网上找的程序修改后的,直接输出utf-8信息。
文件最后,带有一个IP纯真库。方便操作。

<?php
/*
*	author:xhq
*	email:xhq6632@126.com
*	QQ:119948717
*/
header("Content-type: text/html; charset=utf-8");

function getIpss($ip='',$encoding='utf-8'){
if(empty($ip)) $ip = _Cv_Get_Ip();
if(!preg_match("/^\d{1,3}\.\d{1,3}\.\d{1,3}\.\d{1,3}$/", $ip)) { return false; }
if($fd = @fopen(dirname(__FILE__).'/ip.dat', 'rb')){
$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';
}
if($encoding=='utf-8'){
		$ipaddr = mb_convert_encoding($ipaddr,$encoding,'GB2312');
}
return $ipaddr;
}
}
?>
  • ip.rar (2.6 MB)
  • 描述: IP纯真库
  • 下载次数: 13
分享到:
评论

相关推荐

    loadrunner常见录制问题整理

    通过以上步骤设置后,LoadRunner将能够正确识别和处理UTF-8编码的网页内容,避免字符乱码问题。 #### 三、HTML-based script与URL-based script的区别是什么? LoadRunner提供了两种不同的录制模式:...

    ASP经典下载系统Downplus v2.2 MSSQL商业版.zip

    最新版本:2.2.0[GB2312/UTF-8] (2009.04.25) 主要的功能如下: 无限级分类,分类可自由移动,排序. 自定义字段功能,可设置字段表单的形式,如单行、多行文本,单选、多选按钮,单行、多行下拉,隐藏等,可指定默认值,值...

    LoadRunner常见问题整理

    可以通过以下步骤进行设置:打开“录制选项”(Record-Options),切换到“高级”标签页,在“支持的字符集”下选择“UTF-8”等支持的编码格式。这样设置后,录制过程中就不会出现因字符编码不匹配而导致的问题。 #...

    《PHP编程最快明白》第五讲:php目录、文件操作

    为了确保内容的准确性和完整性,本讲解基于Windows服务器环境进行,其中目录名采用GBK编码,而文件内容则采用UTF-8编码。 首先,我们需要了解目录和文件在Windows环境下的编码问题。在PHP中,GBK编码是Windows平台...

    木翼下载系统(MYDOWN) 4.0

    37.优化用户IP获取函数, 对使用代理访问的用户能获取最接近真实的IP地址. 38.文章评论增加文章页面内无刷新机制及盖楼功能. 39.增加快速推荐短标题软件/简述 定义 以及调用标签. 40.参数文件中增加开启/关闭参数:...

Global site tag (gtag.js) - Google Analytics