如何在不同的手机上检测和加载不同的html页面



我必须构建一个移动web应用程序,但每个手机的外观都必须不同。对于iPhone,我需要加载一个不同的html文件,同样适用于android。对于一些甚至不支持javascript的手机,我只需要加载一个带有简单导航的纯html页面。

如何在不同的浏览器中加载不同的布局?我在互联网上搜索了一个移动网络框架,但这些框架只适用于高端手机。在印度,高端智能手机的市场份额相对较小。

在许多编程语言(如PHP和ASP)中,有许多方法可以检索服务器变量。即使在HTML中,您也可以查看HTTP_USER_AGENT等变量,告诉您用户正在使用什么来查看您的网站。我在mobileforge上发现了这段令人难以置信的代码。如果您使用的是PHP,它可以检测几乎所有移动设备,并允许您根据某些标准做出编程决策。

$mobile_browser = '0';
if (preg_match('/(up.browser|up.link|mmp|symbian|smartphone|midp|wap|phone|android)/i', strtolower($_SERVER['HTTP_USER_AGENT']))) {
    $mobile_browser++;
}
if ((strpos(strtolower($_SERVER['HTTP_ACCEPT']),'application/vnd.wap.xhtml+xml') > 0) or ((isset($_SERVER['HTTP_X_WAP_PROFILE']) or isset($_SERVER['HTTP_PROFILE'])))) {
    $mobile_browser++;
}    
$mobile_ua = strtolower(substr($_SERVER['HTTP_USER_AGENT'], 0, 4));
$mobile_agents = array(
'w3c ','acs-','alav','alca','amoi','audi','avan','benq','bird','blac',
'blaz','brew','cell','cldc','cmd-','dang','doco','eric','hipt','inno',
'ipaq','java','jigs','kddi','keji','leno','lg-c','lg-d','lg-g','lge-',
'maui','maxo','midp','mits','mmef','mobi','mot-','moto','mwbp','nec-',
'newt','noki','oper','palm','pana','pant','phil','play','port','prox',
'qwap','sage','sams','sany','sch-','sec-','send','seri','sgh-','shar',
'sie-','siem','smal','smar','sony','sph-','symb','t-mo','teli','tim-',
'tosh','tsm-','upg1','upsi','vk-v','voda','wap-','wapa','wapi','wapp',
'wapr','webc','winw','winw','xda ','xda-');
if (in_array($mobile_ua,$mobile_agents)) {
    $mobile_browser++;
}
if (strpos(strtolower($_SERVER['ALL_HTTP']),'OperaMini') > 0) {
    $mobile_browser++;
}
if (strpos(strtolower($_SERVER['HTTP_USER_AGENT']),'windows') > 0) {
    $mobile_browser = 0;
}
if ($mobile_browser > 0) {
   // do something
}
else {
   // do something else
}   

应该是if(strpos(strtolower($_SERVER['HTTP_USER_AGENT']),'OperaMini')>0)

或者如果(strpos(strtolower($_SERVER[ALL_HTTP']),'OperaMini')>0

我使用ALL_HTTP得到一个调试错误,但当我使用HTTP_USER_AGENT 时,错误就会消失

以下是调试错误,如下所示:调试注意:未定义的索引:第29行header.php中的ALL_HTTP

相关内容

  • 没有找到相关文章

最新更新