文章詳情頁
PHP判斷手機等移動設備的方法
現在移動設備大熱的年代,可能我們在做web前端開發的時候經常會需要用到對移動設備的頁面匹配。當然我們可以用響應式頁面設計來處理前端的匹配問題,但是響應式頁面只是不顯示某些代碼,但是還是會加載到用戶的移動設備中。
為了更好的照顧到用戶手機瀏覽的體驗,減少不必要的加載。我們可以再通過PHP的方式來減少用戶的代碼加載,提高用戶瀏覽頁面時的體驗。
由于現在移動設備的種類繁多、而且瀏覽器五花八門,所以僅僅是通過UA來判斷已經不能完全解決問題了。
下面分享一個PHP現成的方法用于PHP做移動設備的判斷
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869<?php function isMobile() { // 如果有HTTP_X_WAP_PROFILE則一定是移動設備 if (isset ($_SERVER[’HTTP_X_WAP_PROFILE’])) { return true; } // 如果via信息含有wap則一定是移動設備,部分服務商會屏蔽該信息 if (isset ($_SERVER[’HTTP_VIA’])) { // 找不到為flase,否則為true return stristr($_SERVER[’HTTP_VIA’], 'wap') ? true : false; } // 腦殘法,判斷手機發送的客戶端標志,兼容性有待提高 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中查找手機瀏覽器的關鍵字 if (preg_match('/(' . implode(’|’, $clientkeywords) . ')/i', strtolower($_SERVER[’HTTP_USER_AGENT’]))) { return true; } } // 協議法,因為有可能不準確,放到最后判斷 if (isset ($_SERVER[’HTTP_ACCEPT’])) { // 如果只支持wml并且不支持html那一定是移動設備 // 如果支持wml和html但是wml在html之前則是移動設備 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; } } return false; } ?>目前這個方法可以用于大多數的移動設備判斷,使用時也可以根據需要自行添加一些UA的判斷參數
當然,如果使用wp架構的話,里面集成了個這個函數。if(wp_is_moblile()){ echo ’你正在使用移動設備瀏覽’; }else{ echo ’你目前使用的不是移動設備’; }
標簽:
PHP
相關文章:
1. msxml3.dll 錯誤 800c0019 系統錯誤:-2146697191解決方法2. CSS3實例分享之多重背景的實現(Multiple backgrounds)3. asp中response.write("中文")或者js中文亂碼問題4. 讀大數據量的XML文件的讀取問題5. ASP中格式化時間短日期補0變兩位長日期的方法6. CSS Hack大全-教你如何區分出IE6-IE10、FireFox、Chrome、Opera7. HTML DOM setInterval和clearInterval方法案例詳解8. 詳解盒子端CSS動畫性能提升9. 告別AJAX實現無刷新提交表單10. asp批量添加修改刪除操作示例代碼
排行榜