标签:wave 建立 bsp .com 前置 efault alc and roi
1、首先在项目模块下的Common文件夹内建立function.php文件,这样就可以首先执行这里的函数了。所以在这里判断是否是移动端访问的,判断方法如下:
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; }
2、然后再建议一个公共的控制器,里面继承一个公共的控制器,里面设置一个前置方法,判断如果是移动端的就直接显示移动端的主题,然后建立一个主题文件夹Mobile,里面放主题文件。
class PublicController extends Controller{ public function _initialize(){ if (ismobile()) { //设置默认默认主题为 Mobile C(‘DEFAULT_V_LAYER‘,‘Mobile‘); } } }
3、只需要在使用模板的地方继承公共的控制器就可以了。
class IndexController extends PublicController { public function index(){ $this->display(); } }
文章来源:http://www.sunxiaoning.com/language/603.html
标签:wave 建立 bsp .com 前置 efault alc and roi
原文地址:https://www.cnblogs.com/mystudy/p/10795216.html