麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 開發(fā) > PHP > 正文

PHP加純真數(shù)據(jù)庫實現(xiàn)根據(jù)IP跳轉到不同網(wǎng)頁

2024-05-04 21:47:12
字體:
來源:轉載
供稿:網(wǎng)友
這篇文章主要為大家詳細介紹了PHP加純真數(shù)據(jù)庫實現(xiàn)根據(jù)IP跳轉到不同網(wǎng)頁,具有一定的參考價值,感興趣的小伙伴們可以參考一下,有需要的朋友可以收藏方便以后借鑒。

眼看著新浪IP庫就這么“死掉了”,心情很是不好啊,新浪IP庫可以說是IP庫中適用最方便的,前面361模板介紹過《融合新浪IP庫和搜狐IP庫獲取訪客IP地址和IP歸屬地信息并無刷新顯示》,就是新浪IP庫最常用的通過IP實現(xiàn)不同的IP訪問跳轉到不同的頁面。但是現(xiàn)在實現(xiàn)這樣個功能就麻煩多了,雖然我們也有搜狐IP庫,淘寶IP庫等等,但是都不是很方便,今天361模板給大家介紹的是繞過遠程的IP庫,適用純真庫實現(xiàn)。PHP加純真數(shù)據(jù)庫實現(xiàn)根據(jù)IP跳轉到不同網(wǎng)頁。

直接上代碼:

<?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地址獲取真實地址函數(shù)// 參數(shù):$ip - IP地址// 作者:[Discuz!] (C) Comsenz Inc.////===================================function convertip($ip) {    //IP數(shù)據(jù)文件路徑,請根據(jù)情況自行修改    $dat_path = 'QQWry.dat';    //檢查IP地址    if(!ereg("^([0-9]{1,3}.){3}[0-9]{1,3}$", $ip)){        return 'IP Address Error';    }    //打開IP數(shù)據(jù)文件    if(!$fd = @fopen($dat_path, 'rb')){        return 'IP date file not exists or access denied';    }    //分解IP進行運算,得出整形數(shù)    $ip = explode('.', $ip);    $ipNum = $ip[0] * 16777216 + $ip[1] * 65536 + $ip[2] * 256 + $ip[3];    //獲取IP數(shù)據(jù)索引開始和結束位置    $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個字節(jié)        fseek($fd, $ipbegin + 7 * $Middle);        $ipData1 = fread($fd, 4);        if(strlen($ipData1) < 4) {            fclose($fd);            return 'System Error';        }        //提取出來的數(shù)據(jù)轉換成長整形,如果數(shù)據(jù)是負數(shù)則加上2的32次冪        $ip1num = implode('', unpack('L', $ipData1));        if($ip1num < 0) $ip1num += pow(2, 32);        //提取的長整型數(shù)大于我們IP地址則修改結束位置進行下一次循環(huán)        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的數(shù)據(jù)庫。

鏈接: https://pan.baidu.com/s/1U-OsdkotB1IPyvY3zTX3YQ    密碼: bxfv
以上就是PHP加純真數(shù)據(jù)庫實現(xiàn)根據(jù)IP跳轉到不同網(wǎng)頁的全部內容,希望對大家的學習和解決疑問有所幫助,也希望大家多多支持武林網(wǎng)。
發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 国产一区二区午夜 | 亚洲欧美国产精品va在线观看 | 日日狠狠久久 | 一级做人爱c黑人影片 | 黄色av.com| 久久草在线观看视频 | 亚洲3p激情在线观看 | 美女被免费网站在线软件 | 日本中文字幕电影在线观看 | 成人一级免费视频 | 欧美精品久久久久久久久久 | 香蕉视频1024| 国产成人精品无人区一区 | 毛片电影在线看 | 欧美视频国产 | 污黄视频在线播放 | 成人在线观看免费视频 | 成人毛片视频免费看 | 免费专区 - 91爱爱 | 麻豆蜜桃在线观看 | 黄色大片在线免费观看 | 国产精品视频免费在线观看 | 国产一区二区在线免费 | 中文字幕亚洲一区二区三区 | 国产va在线观看免费 | 国产高潮国产高潮久久久91 | 成av人在线观看 | 男女视频免费看 | 精品久久久久久久久久久久久 | 国产在线播放一区二区 | 国产91丝袜在线播放0 | 日韩精品久久久久久 | 日日噜噜噜夜夜狠狠久久蜜桃 | 国产午夜精品一区二区三区免费 | 久久精品国产99国产精品亚洲 | 久久久久久久久久久影视 | 成年人在线免费播放视频 | 欧美三日本三级少妇三级99观看视频 | 久久精品欧美一区二区三区不卡 | 妇女毛片| 久久免费视频一区 |