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

时间:2012-01-28 07:26:07

标签: web-applications mobile-website web-frameworks

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

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

2 个答案:

答案 0 :(得分:1)

有许多方法可以在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
}   

答案 1 :(得分:0)

如果是(strpos(strtolower($ _ SERVER ['HTTP_USER_AGENT']),'OperaMini')> 0)

或者应该是if(strpos(strtolower($ _ SERVER ['ALL_HTTP']),'OperaMini')> 0)

我使用ALL_HTTP收到调试错误,但是当我使用HTTP_USER_AGENT

时错误就消失了

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