超碰人人人人人,亚洲AV午夜福利精品一区二区,亚洲欧美综合区丁香五月1区,日韩欧美亚洲系列

LOGO OA教程 ERP教程 模切知識(shí)交流 PMS教程 CRM教程 開(kāi)發(fā)文檔 其他文檔  
 
網(wǎng)站管理員

PHP中根據(jù)IP地址判斷城市實(shí)現(xiàn)城市切換或跳轉(zhuǎn)代碼

admin
2012年9月27日 10:32 本文熱度 3992

獲取IP地址

. 代碼如下:


<?php
function GetIP() {
if ($_SERVER["HTTP_X_FORWARDED_FOR"])
$ip = $_SERVER["HTTP_X_FORWARDED_FOR"];
else if ($_SERVER["HTTP_CLIENT_IP"])
$ip = $_SERVER["HTTP_CLIENT_IP"];
else if ($_SERVER["REMOTE_ADDR"])
$ip = $_SERVER["REMOTE_ADDR"];
else if (getenv("HTTP_X_FORWARDED_FOR"))
$ip = getenv("HTTP_X_FORWARDED_FOR");
else if (getenv("HTTP_CLIENT_IP"))
$ip = getenv("HTTP_CLIENT_IP");
else if (getenv("REMOTE_ADDR"))
$ip = getenv("REMOTE_ADDR");
else
$ip = "Unknown";
return $ip;
}
echo GetIP();
?>

方法二

. 代碼如下:


function getip ()
{
if (getenv('http_client_ip')) {
$ip = getenv('http_client_ip');
} else if (getenv('http_x_forwarded_for')) {
$ip = getenv('http_x_forwarded_for');
} else if (getenv('remote_addr')) {
$ip = getenv('remote_addr');
} else {
$ip = $_server['remote_addr'];
}
return $ip;

PHP通過(guò)IP地址判斷用戶(hù)所在城市
上文已經(jīng)獲得了用戶(hù)IP地址,接下來(lái),我們就是根據(jù)這個(gè)IP地址獲得用戶(hù)所在城市了。開(kāi)始之前,我們需要下載一個(gè)現(xiàn)成的數(shù)據(jù)庫(kù)QQ IP數(shù)據(jù)庫(kù)。
最新IP地址數(shù)據(jù)庫(kù):http://www.jb51.net/softs/10529.html
使用方法:解壓后QQWry.Dat就是我們想要IP地址數(shù)據(jù)庫(kù),我們新建一個(gè)ipcity文件夾,將數(shù)據(jù)庫(kù)放在下面。QQ IP數(shù)據(jù)庫(kù)使用非常方便,數(shù)據(jù)也很齊全,你可以及時(shí)關(guān)注官方更新以保持?jǐn)?shù)據(jù)最新,強(qiáng)力推薦一下:)
接下來(lái),我們?cè)谏厦娴膇pcity目錄下新建一個(gè)ipaddress.php文件,直接復(fù)制以下代碼進(jìn)去即可,重要的地方也作了相應(yīng)注釋。B段:

. 代碼如下:


<?
/*
函數(shù)名稱(chēng):ipCity
參數(shù)說(shuō)明:$userip——用戶(hù)IP地址
函數(shù)功能:PHP通過(guò)IP地址判斷用戶(hù)所在城市
author:lee
contact:xpsem2010@gmail.com
*/
function ipCity($userip) {
//IP數(shù)據(jù)庫(kù)路徑,這里用的是QQ IP數(shù)據(jù)庫(kù) 20110405 純真版
$dat_path = 'QQWry.dat';
//判斷IP地址是否有效
if(!ereg("^([0-9]{1,3}.){3}[0-9]{1,3}$", $userip)){
return 'IP Address Invalid';
}
//打開(kāi)IP數(shù)據(jù)庫(kù)
if(!$fd = @fopen($dat_path, 'rb')){
return 'IP data file not exists or access denied';
}
//explode函數(shù)分解IP地址,運(yùn)算得出整數(shù)形結(jié)果
$userip = explode('.', $userip);
$useripNum = $userip[0] * 16777216 + $userip[1] * 65536 + $userip[2] * 256 + $userip[3];
//獲取IP地址索引開(kāi)始和結(jié)束位置
$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個(gè)字節(jié)
fseek($fd, $useripbegin + 7 * $Middle);
$useripData1 = fread($fd, 4);
if(strlen($useripData1) < 4) {
fclose($fd);
return 'File Error';
}
//提取出來(lái)的數(shù)據(jù)轉(zhuǎn)換成長(zhǎng)整形,如果數(shù)據(jù)是負(fù)數(shù)則加上2的32次冪
$userip1num = implode('', unpack('L', $useripData1));
if($userip1num < 0) $userip1num += pow(2, 32);
//提取的長(zhǎng)整型數(shù)大于我們IP地址則修改結(jié)束位置進(jìn)行下一次循環(huán)
if($userip1num > $useripNum) {
$EndNum = $Middle;
continue;
}
//取完上一個(gè)索引后取下一個(gè)索引
$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地址對(duì)應(yīng)城市
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地址對(duì)應(yīng)的城市結(jié)果
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';
}
return $useripaddr;
}
?>

PHP根據(jù)IP地址實(shí)現(xiàn)城市切換或跳轉(zhuǎn)
到這里,其實(shí)問(wèn)題已經(jīng)很簡(jiǎn)單了,用簡(jiǎn)單的js就通通搞定。C段如下:
//根據(jù)IP地址跳轉(zhuǎn)指定頁(yè)面js取得城市

. 代碼如下:


var city='<?echo ipCity($xp_UserIp);?>';

//根據(jù)IP地址所有城市跳轉(zhuǎn)到指定頁(yè)面

. 代碼如下:


if(city.indexOf("上海市")>=0){
window.location.;
}

將開(kāi)頭的A段代碼和上面的C段代碼分別放在B段代碼的頭和尾,然后我們?cè)谛枰D(zhuǎn)的頁(yè)面加入以下代碼:

. 代碼如下:


<script src="/ipcity/ipaddress.php" type="text/javascript" language="javascript"></script>

刷新頁(yè)面,是不是達(dá)到預(yù)想的效果了呢?
上面的代碼只是簡(jiǎn)單的判斷了ip那里就跳到那,如果出現(xiàn)如,我想把湖南所有IP都跳到長(zhǎng)沙去,那像衡陽(yáng),劉陽(yáng),耒陽(yáng) 這些就要作多次父線處理了,要想知道請(qǐng)看下集。

該文章在 2012/9/27 10:32:07 編輯過(guò)
關(guān)鍵字查詢(xún)
相關(guān)文章
正在查詢(xún)...
點(diǎn)晴ERP是一款針對(duì)中小制造業(yè)的專(zhuān)業(yè)生產(chǎn)管理軟件系統(tǒng),系統(tǒng)成熟度和易用性得到了國(guó)內(nèi)大量中小企業(yè)的青睞。
點(diǎn)晴PMS碼頭管理系統(tǒng)主要針對(duì)港口碼頭集裝箱與散貨日常運(yùn)作、調(diào)度、堆場(chǎng)、車(chē)隊(duì)、財(cái)務(wù)費(fèi)用、相關(guān)報(bào)表等業(yè)務(wù)管理,結(jié)合碼頭的業(yè)務(wù)特點(diǎn),圍繞調(diào)度、堆場(chǎng)作業(yè)而開(kāi)發(fā)的。集技術(shù)的先進(jìn)性、管理的有效性于一體,是物流碼頭及其他港口類(lèi)企業(yè)的高效ERP管理信息系統(tǒng)。
點(diǎn)晴WMS倉(cāng)儲(chǔ)管理系統(tǒng)提供了貨物產(chǎn)品管理,銷(xiāo)售管理,采購(gòu)管理,倉(cāng)儲(chǔ)管理,倉(cāng)庫(kù)管理,保質(zhì)期管理,貨位管理,庫(kù)位管理,生產(chǎn)管理,WMS管理系統(tǒng),標(biāo)簽打印,條形碼,二維碼管理,批號(hào)管理軟件。
點(diǎn)晴免費(fèi)OA是一款軟件和通用服務(wù)都免費(fèi),不限功能、不限時(shí)間、不限用戶(hù)的免費(fèi)OA協(xié)同辦公管理系統(tǒng)。
Copyright 2010-2025 ClickSun All Rights Reserved