Home >Backend Development >PHP Tutorial >How to determine mobile devices such as mobile phones in php
Now that mobile devices are so popular, we may often need to use page matching for mobile devices when doing web front-end development. Of course, we can use responsive page design to handle the front-end matching problem, but the responsive page only does not display certain codes, but it will still be loaded into the user's mobile device.
In order to better take care of the user's mobile browsing experience and reduce unnecessary loading. We can then use PHP to reduce the user's code loading and improve the user's experience when browsing the page.
Since there are now many types of mobile devices and various browsers, judging by UA alone can no longer completely solve the problem.
The following is a ready-made PHP method for PHP to judge mobile devices
<?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; } ?>
Currently, this method can be used for most mobile device judgments. You can also add some UA judgment parameters according to your needs during use
Of course, If you use the wp architecture, this function is integrated into it.
if(wp_is_moblile()){
echo 'You are browsing on a mobile device';
}else{
echo 'You are not currently using a mobile device';
}