首页 > 开发 > Php > 正文

PHP加纯真数据库实现根据IP跳转到不同网页

2020-07-03 12:51:22
字体:
来源:转载
供稿:网友
这篇文章主要为大家详细介绍了PHP加纯真数据库实现根据IP跳转到不同网页,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,有需要的朋友可以收藏方便以后借鉴。

眼看着新浪IP库就这么“死掉了”,心情很是不好啊,新浪IP库可以说是IP库中适用最方便的,前面361模板介绍过《融合新浪IP库和搜狐IP库获取访客IP地址和IP归属地信息并无刷新显示》,就是新浪IP库最常用的通过IP实现不同的IP访问跳转到不同的页面。但是现在实现这样个功能就麻烦多了,虽然我们也有搜狐IP库,淘宝IP库等等,但是都不是很方便,今天361模板给大家介绍的是绕过远程的IP库,适用纯真库实现。PHP加纯真数据库实现根据IP跳转到不同网页。

直接上代码:

<?header("content-type:text/html;charset=utf-8");   //php获取ip的算法$user_IP = ($_SERVER["HTTP_VIA"]) ? $_SERVER["HTTP_X_FORWARDED_FOR"] : $_SERVER["REMOTE_ADDR"];$user_IP = ($user_IP) ? $user_IP : $_SERVER["REMOTE_ADDR"];//echo $user_IP;//===================================//// 功能:IP地址获取真实地址函数// 参数:$ip - IP地址// 作者:[Discuz!] (C) Comsenz Inc.////===================================function convertip($ip) {    //IP数据文件路径,请根据情况自行修改    $dat_path = 'QQWry.dat';    //检查IP地址    if(!ereg("^([0-9]{1,3}.){3}[0-9]{1,3}$", $ip)){        return 'IP Address Error';    }    //打开IP数据文件    if(!$fd = @fopen($dat_path, 'rb')){        return 'IP date file not exists or access denied';    }    //分解IP进行运算,得出整形数    $ip = explode('.', $ip);    $ipNum = $ip[0] * 16777216 + $ip[1] * 65536 + $ip[2] * 256 + $ip[3];    //获取IP数据索引开始和结束位置    $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;    //使用二分查找法从索引记录中搜索匹配的IP记录    while($ip1num>$ipNum || $ip2num<$ipNum) {        $Middle= intval(($EndNum + $BeginNum) / 2);        //偏移指针到索引位置读取4个字节        fseek($fd, $ipbegin + 7 * $Middle);        $ipData1 = fread($fd, 4);        if(strlen($ipData1) < 4) {            fclose($fd);            return 'System Error';        }        //提取出来的数据转换成长整形,如果数据是负数则加上2的32次幂        $ip1num = implode('', unpack('L', $ipData1));        if($ip1num < 0) $ip1num += pow(2, 32);        //提取的长整型数大于我们IP地址则修改结束位置进行下一次循环        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;}?><script language="javascript">var sf='<?echo convertip($user_IP);?>';if(sf.indexOf("江苏")>=0){        window.location.href="/plus/list.php?tid=28&len=江苏";}else if(sf.indexOf("北京")>=0){        window.location.href="/plus/list.php?tid=28&len=北京";}else if(sf.indexOf("天津")>=0){        window.location.href="/plus/list.php?tid=28&len=天津";}else if(sf.indexOf("河北")>=0){        window.location.href="/plus/list.php?tid=28&len=河北";}else if(sf.indexOf("山西")>=0){        window.location.href="/plus/list.php?tid=28&len=山西";}else if(sf.indexOf("内蒙古")>=0){        window.location.href="/plus/list.php?tid=28&len=内蒙古";}else if(sf.indexOf("上海")>=0){        window.location.href="/plus/list.php?tid=28&len=上海";}else if(sf.indexOf("浙江")>=0){        window.location.href="/plus/list.php?tid=28&len=浙江";}else if(sf.indexOf("山东")>=0){        window.location.href="/plus/list.php?tid=28&len=山东";}else if(sf.indexOf("安徽")>=0){        window.location.href="/plus/list.php?tid=28&len=安徽";}else if(sf.indexOf("辽宁")>=0){        window.location.href="/plus/list.php?tid=28&len=辽宁";}else if(sf.indexOf("吉林")>=0){        window.location.href="/plus/list.php?tid=28&len=吉林";}else if(sf.indexOf("黑龙江")>=0){        window.location.href="/plus/list.php?tid=28&len=黑龙江";}else if(sf.indexOf("湖北")>=0){        window.location.href="/plus/list.php?tid=28&len=湖北";}else if(sf.indexOf("湖南")>=0){        window.location.href="/plus/list.php?tid=28&len=湖南";}else if(sf.indexOf("河南")>=0){        window.location.href="/plus/list.php?tid=28&len=河南";}else if(sf.indexOf("江西")>=0){        window.location.href="/plus/list.php?tid=28&len=江西";}else if(sf.indexOf("广东")>=0){        window.location.href="/plus/list.php?tid=28&len=广东";}else if(sf.indexOf("广西")>=0){        window.location.href="/plus/list.php?tid=28&len=广西";}else if(sf.indexOf("海南")>=0){        window.location.href="/plus/list.php?tid=28&len=海南";}else if(sf.indexOf("福建")>=0){        window.location.href="/plus/list.php?tid=28&len=福建";}else if(sf.indexOf("四川")>=0){        window.location.href="/plus/list.php?tid=28&len=四川";}else if(sf.indexOf("重庆")>=0){        window.location.href="/plus/list.php?tid=28&len=重庆";}else if(sf.indexOf("贵州")>=0){        window.location.href="/plus/list.php?tid=28&len=贵州";}else if(sf.indexOf("云南")>=0){        window.location.href="/plus/list.php?tid=28&len=云南";}else if(sf.indexOf("西藏")>=0){        window.location.href="/plus/list.php?tid=28&len=西藏";}else if(sf.indexOf("陕西")>=0){        window.location.href="/plus/list.php?tid=28&len=陕西";}else if(sf.indexOf("甘肃")>=0){        window.location.href="/plus/list.php?tid=28&len=甘肃";}else if(sf.indexOf("新疆")>=0){        window.location.href="/plus/list.php?tid=28&len=新疆";}else if(sf.indexOf("青海")>=0){        window.location.href="/plus/list.php?tid=28&len=青海";}else if(sf.indexOf("宁夏")>=0){        window.location.href="/plus/list.php?tid=28&len=宁夏";}else if(sf.indexOf("香港")>=0){        window.location.href="/plus/list.php?tid=28&len=香港";}else if(sf.indexOf("澳门")>=0){        window.location.href="/plus/list.php?tid=28&len=澳门";}else if(sf.indexOf("台湾")>=0){        window.location.href="/plus/list.php?tid=28&len=台湾";}else{        window.location.href="/plus/list.php?tid=28";}</script>

因为361模板给用户做的是UTF-8的页面,所有这里也给大家分享一份很少见的纯真的UTF-8的数据库。

链接: https://pan.baidu.com/s/1U-OsdkotB1IPyvY3zTX3YQ    密码: bxfv
以上就是PHP加纯真数据库实现根据IP跳转到不同网页的全部内容,希望对大家的学习和解决疑问有所帮助,也希望大家多多支持错新网。
发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表