28

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

エラー PHP通知:未定義のインデックス:7行目のUtils.phpの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
        );
    }
4

2 に答える 2

59

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'])
               : '';
于 2013-01-02T23:26:27.980 に答える
9

issetを使用します。

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

    if (preg_match('/opera/', $userAgent)) {
        $name = 'opera';
    } [... yourcode ...]
}
于 2013-01-02T23:26:19.313 に答える