本文實(shí)例總結(jié)了PHP判斷訪客是否手機(jī)端(移動端瀏覽器)訪問的方法。分享給大家供大家參考,具體如下:
在平常工作開發(fā)中,我們通常需要開發(fā)出PC端和移動端兩個不同的系統(tǒng),從而根據(jù)訪問端的不同進(jìn)入到不同的操作界面中。這就需要我們首先要對訪問的客戶端進(jìn)行判斷是PC端還是移動端。
本博文討論使用PHP判斷訪問端是否是移動端(或是移動端瀏覽器)從而確定是移動端訪問的4種方法:
1、根據(jù) HTTP_X_WAP_PROFILE是否存在進(jìn)行判斷,存在則是移動端(部分服務(wù)商會屏蔽該信息)
/**
* 是否是移動端訪問
* @desc 判斷是否是移動端進(jìn)行訪問
* @方法一:判斷是否有HTTP_X_WAP_PROFILE,有則一定是移動設(shè)備。
* @return bool
* $Author: Zhihua_W
*/
function isMobile1()
{
if (isset ($_SERVER['HTTP_X_WAP_PROFILE'])) {
return true;
} else {
return false;
}
}
2、根據(jù)HTTP_VIA信息進(jìn)行判斷,如果VIA信息含有wap則是移動設(shè)備(部分服務(wù)商會屏蔽該信息)
/**
* 是否是移動端訪問
* @desc 判斷是否是移動端進(jìn)行訪問
* @方法二:判斷HTTP_VIA信息是否含有wap信息,有則一定是移動設(shè)備。
* @return bool
* $Author: Zhihua_W
*/
function isMobile2 ()
{
if (isset ($_SERVER['HTTP_VIA'])) {
return true;
} else {
return false;
}
}
3、根據(jù)手機(jī)發(fā)送的客戶端標(biāo)志進(jìn)行判斷,此方法比較笨,并且兼容性有待提高
/**
* 是否是移動端訪問
* @desc 判斷是否是移動端進(jìn)行訪問
* @方法三:判斷是否有HTTP_USER_AGENT信息是否是手機(jī)發(fā)送的客戶端標(biāo)志,有則一定是移動設(shè)備。
* @return bool
* $Author: Zhihua_W
*/
function isMobile3 ()
{
if (isset ($_SERVER['HTTP_USER_AGENT'])) {
$clientkeywords = array ('nokia', 'sony','ericsson','mot',
'samsung','htc','sgh','lg','sharp',
'sie-','philips','panasonic','alcatel',
'lenovo','iphone','ipod','blackberry',
'meizu','android','netfront','symbian',
'ucweb','windowsce','palm','operamini',
'operamobi','openwave','nexusone','cldc',
'midp','wap','mobile'
);
// 從HTTP_USER_AGENT中查找手機(jī)瀏覽器的關(guān)鍵字
if (preg_match("/(" . implode('|', $clientkeywords) . ")/i", strtolower($_SERVER['HTTP_USER_AGENT']))){
return true;
} else {
return false;
}
} else {
return false;
}
}
4、根據(jù)協(xié)議進(jìn)行判斷,此方法有可能不正確或是判斷不出來
/**
* 是否是移動端訪問
* @desc 判斷是否是移動端進(jìn)行訪問
* @方法四:判斷HTTP_ACCEPT信息
* @return bool
* $Author: Zhihua_W
*/
function isMobile4()
{
if (isset ($_SERVER['HTTP_ACCEPT'])) {
// 如果只支持wml并且不支持html那一定是移動設(shè)備
// 如果支持wml和html但是wml在html之前則是移動設(shè)備
if ((strpos($_SERVER['HTTP_ACCEPT'], 'vnd.wap.wml') !== false) (strpos($_SERVER['HTTP_ACCEPT'], 'text/html') === false || (strpos($_SERVER['HTTP_ACCEPT'], 'vnd.wap.wml') strpos($_SERVER['HTTP_ACCEPT'], 'text/html')))) {
return true;
} else {
return false;
}
} else {
return false;
}
}
以上四種方法都存在部分缺陷和兼容性不好等問題,所以博友在用的時候可以將四種方法結(jié)合成一個方法進(jìn)行判斷。
PS:這里再為大家推薦2款功能相似的瀏覽器判斷在線工具供大家參考:
在線瀏覽器信息檢測工具:
http://tools.jb51.net/aideddesign/browser_info
常用瀏覽器(PC,移動) user-agent:
http://tools.jb51.net/table/useragent
更多關(guān)于PHP相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《PHP網(wǎng)絡(luò)編程技巧總結(jié)》、《php正則表達(dá)式用法總結(jié)》、《php curl用法總結(jié)》、《PHP數(shù)組(Array)操作技巧大全》、《php字符串(string)用法總結(jié)》、《PHP數(shù)據(jù)結(jié)構(gòu)與算法教程》、《php程序設(shè)計算法總結(jié)》、《PHP數(shù)學(xué)運(yùn)算技巧總結(jié)》及《php常見數(shù)據(jù)庫操作技巧匯總》
希望本文所述對大家PHP程序設(shè)計有所幫助。
您可能感興趣的文章:- js判斷瀏覽器的環(huán)境(pc端,移動端,還是微信瀏覽器)
- 如何實(shí)現(xiàn)移動端瀏覽器不顯示 pc 端的廣告
- js檢測瀏覽器版本、核心、是否移動端示例
- js實(shí)現(xiàn)點(diǎn)擊圖片在屏幕中間彈出放大效果
- 使用JavaScript實(shí)現(xiàn)點(diǎn)擊循環(huán)切換圖片效果
- JS點(diǎn)擊圖片彈出文件選擇框并覆蓋原圖功能的實(shí)現(xiàn)代碼
- JS點(diǎn)擊縮略圖整屏居中放大圖片效果
- 原生JS實(shí)現(xiàn)隱藏顯示圖片 JS實(shí)現(xiàn)點(diǎn)擊切換圖片效果
- 如何阻止移動端瀏覽器點(diǎn)擊圖片瀏覽