모바일 기기가 대중화되는 시대에 웹 프런트엔드 개발을 할 때 모바일 기기에 맞는 페이지를 일치시켜야 하는 경우가 종종 있습니다. 물론 반응형 페이지 디자인을 사용하여 프런트 엔드 일치 문제를 처리할 수 있지만 반응형 페이지는 특정 코드를 표시하지 않지만 여전히 사용자의 모바일 장치에 로드됩니다.
사용자의 모바일 브라우징 경험을 더 잘 관리하려면 불필요한 로딩을 줄이세요. 그런 다음 PHP를 사용하여 사용자의 코드 로딩을 줄이고 페이지 탐색 시 사용자 경험을 향상시킬 수 있습니다.
이제는 다양한 종류의 모바일 디바이스와 다양한 브라우저가 있기 때문에 단순히 UA만으로는 문제를 완전히 해결할 수 없습니다.
다음은 PHP가 모바일 장치를 판단하기 위해 미리 만들어진 PHP 방법입니다
<?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; } ?>
현재 이 방법은 대부분의 모바일 장치를 판단하는 데 사용할 수 있으며 다음과 같이 직접 사용할 수도 있습니다. 필요 UA 판단 매개변수 추가
물론 wp 아키텍처를 사용하는 경우 이 기능이 통합되어 있습니다.
if(wp_is_moblile()){
echo '모바일 기기에서 검색 중입니다.'
}else{
echo '현재 모바일 기기를 사용하고 있지 않습니다.'
}