目前訪問頁面的要切換成手機端和PC端,原理是經過對設備做出判斷,顯示不一樣的功能和頁面。css
若是手機端和PC端的功能結構不相同,通常會寫兩套系統,一套適用於PC端,一套適用於手機端。html
若是功能相同,則只須要更換模板。android
首先這是一套判斷設備的代碼。web
function ismobile() { // 若是有HTTP_X_WAP_PROFILE則必定是移動設備 if (isset ($_SERVER['HTTP_X_WAP_PROFILE'])) return true; //此條摘自TPM智能切換模板引擎,適合TPM開發 if(isset ($_SERVER['HTTP_CLIENT']) &&'PhoneClient'==$_SERVER['HTTP_CLIENT']) 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; }
這個函數用於判斷設備類型是手機仍是PC。windows
把這個函數放到公共函數裏,在自動加載的類方法裏進行判斷。瀏覽器
例如在TP框架下,我把這段函數放在公共的function裏。框架
而後在基本控制器裏判斷,若是爲手機端,則切換模板爲手機主題。iphone
class IndexController extends BaseController { Public function _initialize(){ //移動設備瀏覽,則切換模板 if (ismobile()) { //設置默認默認主題爲 Mobile C('DEFAULT_THEME','Mobile'); } //............你的更多代碼....... } }
一樣要更換功能則須要找到更底層的控制器進行判斷。函數
這個方法不適用全部項目,可是原理如此。spa