PHP Undefined index: HTTP_USER_AGENT
Следующий код проверяет пользовательский агент, обращающийся к сайту, но я получаю сообщение об ошибке. Что мне нужно обновить для размещения сценариев, в которых не установлен пользовательский агент?
ОШИБКА
Примечание PHP: Undefined index: HTTP_USER_AGENT в Utils.php в строке 7
CODE
public static function detectBrowser()
{
$userAgent = strtolower($_SERVER['HTTP_USER_AGENT']);
if (preg_match('/opera/', $userAgent)) {
$name = 'opera';
}
elseif (preg_match('/webkit/', $userAgent)) {
$name = 'safari';
}
elseif (preg_match('/msie/', $userAgent)) {
$name = 'msie';
}
elseif (preg_match('/mozilla/', $userAgent) && !preg_match('/compatible/', $userAgent)) {
$name = 'mozilla';
}
else {
$name = 'unrecognized';
}
if (preg_match('/.+(?:rv|it|ra|ie)[\/: ]([\d.]+)/', $userAgent, $matches)) {
$version = $matches[1];
}
else {
$version = 'unknown';
}
if (preg_match('/linux/', $userAgent)) {
$platform = 'linux';
}
elseif (preg_match('/macintosh|mac os x/', $userAgent)) {
$platform = 'mac';
}
elseif (preg_match('/windows|win32/', $userAgent)) {
$platform = 'windows';
}
else {
$platform = 'unrecognized';
}
return array(
'name' => $name,
'version' => $version,
'platform' => $platform,
'userAgent' => $userAgent
);
}
Ответы
Ответ 1
Заголовок User-Agent не является обязательным. Брандмауэры могут фильтровать его, или люди могут настроить своих клиентов, чтобы опустить его. Просто проверьте isset()
, если он существует. Или даже лучше использовать !empty()
в качестве пустого заголовка тоже не полезно:
public static function detectBrowser() {
if(empty($_SERVER['HTTP_USER_AGENT'])) {
return array(
'name' => 'unrecognized',
'version' => 'unknown',
'platform' => 'unrecognized',
'userAgent' => ''
);
}
// your old code here
}
Однако, поскольку весь ваш код работает нормально на пустой строке, а также дает "неизвестные" значения, вы можете просто изменить следующую строку:
$userAgent = strtolower($_SERVER['HTTP_USER_AGENT']);
вот так:
$userAgent = isset($_SERVER['HTTP_USER_AGENT'])
? strtolower($_SERVER['HTTP_USER_AGENT'])
: '';
Ответ 2
используйте isset:
if( !isset( $_SERVER['HTTP_USER_AGENT'])){
$name = "none";
}else{
$userAgent = strtolower($_SERVER['HTTP_USER_AGENT']);
if (preg_match('/opera/', $userAgent)) {
$name = 'opera';
} [... yourcode ...]
}