web-dev-qa-db-ja.com

PHP未定義のインデックス:HTTP_USER_AGENT

次のコードは、サイトにアクセスするユーザーエージェントを検証しますが、エラーが発生します。ユーザーエージェントが設定されていないシナリオに対応するには、何を更新する必要がありますか?

[〜#〜]エラー[〜#〜] PHP注意:未定義のインデックス:Utils.phpの7行目のHTTP_USER_AGENT

[〜#〜]コード[〜#〜]

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
        );
    }
20
PeanutsMonkey

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'])
               : '';
50
ThiefMaster

issetを使用:

if( !isset( $_SERVER['HTTP_USER_AGENT'])){
    $name = "none";
}else{
     $userAgent = strtolower($_SERVER['HTTP_USER_AGENT']);

    if (preg_match('/opera/', $userAgent)) {
        $name = 'opera';
    } [... yourcode ...]
}
6
Green Black