web-dev-qa-db-ja.com

Safari、Chrome、IE、Firefox、およびOperaブラウザを検出する方法

FF、Chrome、IE、Opera、およびSafari用の5つのアドオン/拡張機能があります。

ユーザのブラウザを認識し、対応するアドオンをダウンロードするために(インストールボタンがクリックされたら)リダイレクトするにはどうすればよいですか?

658
FrankC

ブラウザの信頼性の高い検出のためのグーグルは、しばしばユーザエージェント文字列をチェックすることになります。この値を偽装するのは簡単なので、このメソッドはnot信頼できます。
duck-typing によってブラウザを検出する方法を書きました。

拡張機能をインストールするためのブラウザ固有の指示を表示するなど、本当に必要な場合にのみブラウザ検出方法を使用してください。 可能な場合は機能検出を使用してください。

デモ: https://jsfiddle.net/311aLtkz/ /

// Opera 8.0+
var isOpera = (!!window.opr && !!opr.addons) || !!window.opera || navigator.userAgent.indexOf(' OPR/') >= 0;

// Firefox 1.0+
var isFirefox = typeof InstallTrigger !== 'undefined';

// Safari 3.0+ "[object HTMLElementConstructor]" 
var isSafari = /constructor/i.test(window.HTMLElement) || (function (p) { return p.toString() === "[object SafariRemoteNotification]"; })(!window['safari'] || (typeof safari !== 'undefined' && safari.pushNotification));

// Internet Explorer 6-11
var isIE = /*@[email protected]*/false || !!document.documentMode;

// Edge 20+
var isEdge = !isIE && !!window.StyleMedia;

// Chrome 1 - 71
var isChrome = !!window.chrome && (!!window.chrome.webstore || !!window.chrome.runtime);

// Blink engine detection
var isBlink = (isChrome || isOpera) && !!window.CSS;

信頼性の分析

前の方法 はブラウザを検出するためにレンダリングエンジンのプロパティ( -moz-box-sizing-webkit-transform)に依存していました。これらの接頭辞は最終的に削除されるので、検出をさらに堅牢にするために、ブラウザ固有の特性に切り替えました。

  • Internet Explorer:JScriptの 条件付きコンパイル (IE 9まで)および document.documentMode
  • Edge:TridentおよびEdgeブラウザでは、Microsoftの実装はStyleMediaコンストラクタを公開しています。トライデントを除外すると、Edgeが残ります。
  • Firefox:アドオンをインストールするためのFirefoxのAPI: InstallTrigger
  • Chrome:文書化された chrome.webstore オブジェクトを含むいくつかのプロパティを含む、グローバルなchromeオブジェクト。
    • Update 3 chrome.webstoreは最近のバージョンでは非推奨で未定義です
  • Safari:コンストラクタの命名における独自の命名パターン。これは、リストされているすべてのプロパティの中で最も耐久性の低い方法です。 Safari 9.1.3ではそれが修正されました。そのため、バージョン7.1以降に導入されたSafariRemoteNotificationをチェックして、3.0以降のすべてのSafarisをカバーしています。
  • Opera:window.operaは何年も前から存在していましたが、 は削除されるでしょう OperaがエンジンをBlink + V8(Chromiumによって使用される)に置き換えたとき。
    • アップデート1: Opera 15がリリースされました 、そのUA文字列はChromeのように見えますが、 "OPR"が追加されています。このバージョンではchromeオブジェクトが定義されています(しかしchrome.webstoreは定義されていません)。 OperaはChromeのクローン作成に全力を尽くしているので、この目的のためにユーザーエージェントスニッフィングを使用します。
    • アップデート2:!!window.opr && opr.addonsOpera 20+ (常緑樹)の検出に使用できます。
  • Blink:CSS.supports()がBlinkで導入されました GoogleがChrome 28をオンにした後。

で正常にテストされました。

  • Firefox 0.8 - 61
  • Chrome 1.0 - 71
  • オペラ8.0 - 34
  • サファリ3.0 - 10
  • IE 6 - 11
  • エッジ - 20〜42

2016年11月に更新され、9.1.3以降のSafariブラウザの検出が含まれています

2018年8月に更新され、クロム、firefox IE、およびEdgeに関する最新の成功したテストが更新されました。

2019年1月に更新され、(window.chrome.webstoreの廃止のため)クロム検出が修正され、クロムに関する最新の成功したテストが含まれます。

1442
Rob W

以下の方法でブラウザのバージョンを確認できます。

    <!DOCTYPE html>
    <html>
    <body>
    <p>What is the name(s) of your browser?</p>
    <button onclick="myFunction()">Try it</button>
    <p id="demo"></p>
    <script>

    function myFunction() { 
     if((navigator.userAgent.indexOf("Opera") || navigator.userAgent.indexOf('OPR')) != -1 ) 
    {
        alert('Opera');
    }
    else if(navigator.userAgent.indexOf("Chrome") != -1 )
    {
        alert('Chrome');
    }
    else if(navigator.userAgent.indexOf("Safari") != -1)
    {
        alert('Safari');
    }
    else if(navigator.userAgent.indexOf("Firefox") != -1 ) 
    {
         alert('Firefox');
    }
    else if((navigator.userAgent.indexOf("MSIE") != -1 ) || (!!document.documentMode == true )) //IF IE > 10
    {
      alert('IE'); 
    }  
    else 
    {
       alert('unknown');
    }
    }
    </script>

    </body>
    </html>

あなたがIEブラウザのバージョンだけを知る必要があるなら、あなたは以下のコードに従うことができます。このコードはIE6からIE11までのバージョンに適しています。

<!DOCTYPE html>
<html>
<body>

<p>Click on Try button to check IE Browser version.</p>

<button onclick="getInternetExplorerVersion()">Try it</button>

<p id="demo"></p>

<script>
function getInternetExplorerVersion() {
   var ua = window.navigator.userAgent;
        var msie = ua.indexOf("MSIE ");
        var rv = -1;

        if (msie > 0 || !!navigator.userAgent.match(/Trident.*rv\:11\./))      // If Internet Explorer, return version number
        {               

            if (isNaN(parseInt(ua.substring(msie + 5, ua.indexOf(".", msie))))) {
                //For IE 11 >
                if (navigator.appName == 'Netscape') {
                    var ua = navigator.userAgent;
                    var re = new RegExp("Trident/.*rv:([0-9]{1,}[\.0-9]{0,})");
                    if (re.exec(ua) != null) {
                        rv = parseFloat(RegExp.$1);
                        alert(rv);
                    }
                }
                else {
                    alert('otherbrowser');
                }
            }
            else {
                //For < IE11
                alert(parseInt(ua.substring(msie + 5, ua.indexOf(".", msie))));
            }
            return false;
        }}
</script>

</body>
</html>
108
Nimesh

そのためにlibを使用するのはやり過ぎるかもしれませんが、スレッドを充実させるために、 is.js をチェックする方法があります。

is.firefox();
is.ie(6);
is.not.safari();
56
Rafael Eyng

誰かがこれを役に立つと思った場合に備えて、私は Rob Wの答え を、複数の変数を浮動するのではなく、ブラウザ文字列を返す関数にしました。ブラウザもまた何度もロードしなければ実際には変更できないので、次に関数が呼び出されたときにそれを解決する必要がないように結果をキャッシュに入れました。

/**
 * Gets the browser name or returns an empty string if unknown. 
 * This function also caches the result to provide for any 
 * future calls this function has.
 *
 * @returns {string}
 */
var browser = function() {
    // Return cached result if avalible, else get result then cache it.
    if (browser.prototype._cachedResult)
        return browser.prototype._cachedResult;

    // Opera 8.0+
    var isOpera = (!!window.opr && !!opr.addons) || !!window.opera || navigator.userAgent.indexOf(' OPR/') >= 0;

    // Firefox 1.0+
    var isFirefox = typeof InstallTrigger !== 'undefined';

    // Safari 3.0+ "[object HTMLElementConstructor]" 
    var isSafari = /constructor/i.test(window.HTMLElement) || (function (p) { return p.toString() === "[object SafariRemoteNotification]"; })(!window['safari'] || safari.pushNotification);

    // Internet Explorer 6-11
    var isIE = /*@[email protected]*/false || !!document.documentMode;

    // Edge 20+
    var isEdge = !isIE && !!window.StyleMedia;

    // Chrome 1+
    var isChrome = !!window.chrome && !!window.chrome.webstore;

    // Blink engine detection
    var isBlink = (isChrome || isOpera) && !!window.CSS;

    return browser.prototype._cachedResult =
        isOpera ? 'Opera' :
        isFirefox ? 'Firefox' :
        isSafari ? 'Safari' :
        isChrome ? 'Chrome' :
        isIE ? 'IE' :
        isEdge ? 'Edge' :
        isBlink ? 'Blink' :
        "Don't know";
};

console.log(browser());
41
willsquire

2019年2月現在のブラウザ検出を処理する著名なライブラリがいくつかあります。

Bowser by lancedikson - 3,216★s - 最終更新日2019年2月9日 - 2.9KB

console.log(bowser);
document.write("You are using " + bowser.name +
               " v" + bowser.version + 
               " on " + bowser.osname);
<script src="https://cdnjs.cloudflare.com/ajax/libs/bowser/1.9.3/bowser.min.js"></script>

Platform.js by bestiejs - 2,250★s - 最終更新2018年10月30日 - 5.9KB

console.log(platform);
document.write("You are using " + platform.name +
               " v" + platform.version + 
               " on " + platform.os);
<script src="https://cdnjs.cloudflare.com/ajax/libs/platform/1.3.5/platform.min.js"></script>

jQuery Browser by gabceb - 504★s - 最終更新日2015年11月23日 - 1.3KB

console.log($.browser)
document.write("You are using " + $.browser.name +
               " v" + $.browser.versionNumber + 
               " on " + $.browser.platform);
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery-browser/0.1.0/jquery.browser.min.js"></script>

Detect.js(アーカイブ済み) by darcyclarke - 522★s - 最終更新日2015年10月26日 - 2.9KB

var result = detect.parse(navigator.userAgent);
console.log(result);
document.write("You are using " + result.browser.family +
               " v" + result.browser.version + 
               " on " + result.os.family);
<script src="https://cdnjs.cloudflare.com/ajax/libs/Detect.js/2.2.2/detect.min.js"></script>

ブラウザ検出(アーカイブ) by QuirksMode - 最終更新2013年11月14日 - 884B

console.log(BrowserDetect)
document.write("You are using " + BrowserDetect.browser +
               " v" + BrowserDetect.version + 
               " on " + BrowserDetect.OS);
<script src="https://kylemit.github.io/libraries/libraries/BrowserDetect.js"></script>

注目すべき言及:

  • whichBrowser - 1,355★s - 最終更新2018年10月2日
  • Modernizr - 23,397★s - 最後に更新された2019年1月12日 - 給餌された馬を養うために、特徴検出はどんな canIuse スタイルの質問も駆り立てるべきです。ブラウザ検出は、カスタマイズされた画像、ダウンロードファイル、または個々のブラウザ用の指示を提供するためだけのものです。

参考文献

26
KyleMit

Microsoft EdgeとBlinkの検出を含む、Robの回答を2016年に修正したものがあります。

edit :上のRobの答えをこの情報で更新しました。)

// Opera 8.0+ (UA detection to detect Blink/v8-powered Opera)
isOpera = !!window.opera || navigator.userAgent.indexOf(' OPR/') >= 0;
// Firefox 1.0+
isFirefox = typeof InstallTrigger !== 'undefined';
// Safari 3.0+
isSafari = /constructor/i.test(window.HTMLElement) || (function (p) { return p.toString() === "[object SafariRemoteNotification]"; })(!window['safari'] || safari.pushNotification);
// Internet Explorer 6-11
isIE = /*@[email protected]*/false || !!document.documentMode;
// Edge 20+
isEdge = !isIE && !!window.StyleMedia;
// Chrome 1+
isChrome = !!window.chrome && !!window.chrome.webstore;
// Blink engine detection
isBlink = (isChrome || isOpera) && !!window.CSS;

/* Results: */
console.log("isOpera", isOpera);
console.log("isFirefox", isFirefox);
console.log("isSafari", isSafari);
console.log("isIE", isIE);
console.log("isEdge", isEdge);
console.log("isChrome", isChrome);
console.log("isBlink", isBlink);

このアプローチの利点は、ブラウザエンジンのプロパティに依存しているため、YandexやVivaldiなど、そのエンジンを使用している主要ブラウザと実質的に互換性のある派生ブラウザであってもカバーできることです。例外はOperaです。これはユーザーエージェントの盗聴に依存していますが、今日(つまりバージョン15以降)でもOperaはそれ自体がBlinkのシェルに過ぎません。

11
pilau

皆さん、ありがとうございました。私は最近のブラウザでコードスニペットをテストしました:Chrome 55、Firefox 50、IE 11およびEdge 38、そして私はそれらすべてのために私のために働いた組み合わせを思い付きました。私はそれが改善されることができると確信しています、しかしそれは誰でも必要とする人のための迅速な解決策です:

var browser_name = '';
isIE = /*@[email protected]*/false || !!document.documentMode;
isEdge = !isIE && !!window.StyleMedia;
if(navigator.userAgent.indexOf("Chrome") != -1 && !isEdge)
{
    browser_name = 'chrome';
}
else if(navigator.userAgent.indexOf("Safari") != -1 && !isEdge)
{
    browser_name = 'safari';
}
else if(navigator.userAgent.indexOf("Firefox") != -1 ) 
{
    browser_name = 'firefox';
}
else if((navigator.userAgent.indexOf("MSIE") != -1 ) || (!!document.documentMode == true )) //IF IE > 10
{
    browser_name = 'ie';
}
else if(isEdge)
{
    browser_name = 'Edge';
}
else 
{
   browser_name = 'other-browser';
}
$('html').addClass(browser_name);

ブラウザの名前で、CSSクラスをHTMLに追加します。

8
dnns

ショートバリアント

var browser = (function(agent){
            switch(true){
                case agent.indexOf("Edge") > -1: return "Edge";
                case agent.indexOf("opr") > -1 && !!window.opr: return "opera";
                case agent.indexOf("chrome") > -1 && !!window.chrome: return "chrome";
                case agent.indexOf("trident") > -1: return "ie";
                case agent.indexOf("firefox") > -1: return "firefox";
                case agent.indexOf("safari") > -1: return "safari";
                default: return "other";
            }
        })(window.navigator.userAgent.toLowerCase());
console.log(browser)
7
Alex Nikulin

trycatchを使用して、異なるブラウザエラーメッセージを使用できます。 IEとEdgeは混同されていましたが、私はRob Wのアヒルタイピングを使いました(このプロジェクトに基づいています: https://www.khanacademy.org/computer-programming/i-have- opera/2395080328 )。

var getBrowser = function() {        
    try {
        var e;
        var f = e.width;
    } catch(e) {
        var err = e.toString();

        if(err.indexOf("not an object") !== -1) {
            return "safari";
        } else if(err.indexOf("Cannot read") !== -1) {
            return "chrome";
        } else if(err.indexOf("e is undefined") !== -1) {
            return "firefox";
        } else if(err.indexOf("Unable to get property 'width' of undefined or null reference") !== -1) {
            if(!(false || !!document.documentMode) && !!window.StyleMedia) {
                return "Edge";
            } else {
                return "IE";
            }
        } else if(err.indexOf("cannot convert e into object") !== -1) {
            return "opera";
        } else {
            return undefined;
        }
    }
};
6
Mason Jones

すべての一般的なブラウザで動作する、あまり「ハックな」方法もあります。 Googleは Closure Library にブラウザチェックを含めました。特に、 goog.userAgentgoog.userAgent.product を見てください。このようにして、ブラウザの表示方法が変わっても最新の状態になります(クロージャコンパイラの最新バージョンを常に実行している場合)。

4
Albert

デスクトップおよびモバイルでのブラウザの検出:Edge、Opera、Chrome、Safari、Firefox、IE

私は@nimeshコードにいくつかの変更を加えました。これは現在Edgeでも動作しており、Operaの問題は修正されています。

function getBrowserName() {

    if ( navigator.userAgent.indexOf("Edge") > -1 && navigator.appVersion.indexOf('Edge') > -1 ) {
        return 'Edge';
    }
    else if( navigator.userAgent.indexOf("Opera") != -1 || navigator.userAgent.indexOf('OPR') != -1 )
    {
        return 'Opera';
    }
    else if( navigator.userAgent.indexOf("Chrome") != -1 )
    {
        return 'Chrome';
    }
    else if( navigator.userAgent.indexOf("Safari") != -1)
    {
        return 'Safari';
    }
    else if( navigator.userAgent.indexOf("Firefox") != -1 ) 
    {
        return 'Firefox';
    }
    else if( ( navigator.userAgent.indexOf("MSIE") != -1 ) || (!!document.documentMode == true ) ) //IF IE > 10
    {
        return 'IE';
    }  
    else 
    {
        return 'unknown';
    }
}

ありがとう@nimeshユーザー:2063564

3
Irshad Khan

それがだれにとっても有用であるかどうかはわかりませんが、TypeScriptを快適にするための変種です。

export function getBrowser() {

// Opera 8.0+
if ((!!window["opr"] && !!["opr"]["addons"]) || !!window["opera"] || navigator.userAgent.indexOf(' OPR/') >= 0) {
    return 'opera';
}

// Firefox 1.0+
if (typeof window["InstallTrigger"] !== 'undefined') {
    return 'firefox';
}

// Safari 3.0+ "[object HTMLElementConstructor]" 
if (/constructor/i.test(window["HTMLElement"]) || (function(p) { return p.toString() === "[object SafariRemoteNotification]"; })(!window['safari'] || (typeof window["safari"] !== 'undefined' && window["safari"].pushNotification))) {
    return 'safari';
}

// Internet Explorer 6-11
if (/*@[email protected]*/false || !!document["documentMode"]) {
    return 'ie';
}

// Edge 20+
if (!(/*@[email protected]*/false || !!document["documentMode"]) && !!window["StyleMedia"]) {
    return 'Edge';
}

// Chrome 1+
if (!!window["chrome"] && !!window["chrome"].webstore) {
    return 'chrome';
}

// Blink engine detection
if (((!!window["chrome"] && !!window["chrome"].webstore) || ((!!window["opr"] && !!["opr"]["addons"]) || !!window["opera"] || navigator.userAgent.indexOf(' OPR/') >= 0)) && !!window["CSS"]) {
    return 'blink';
}

}

3
Tony Smith

特定のブラウザの数値バージョンを知る必要がある場合は、次のスニペットを使用できます。現在のところ、Chrome/Chromium/Firefoxのバージョンがわかります。

var match = $window.navigator.userAgent.match(/(?:Chrom(?:e|ium)|Firefox)\/([0-9]+)\./);
var ver = match ? parseInt(match[1], 10) : 0;
3
Valera Tumash

UAParser は、userAgent文字列からブラウザ、エンジン、OS、CPU、およびデバイスタイプ/モデルを識別するための軽量JavaScriptライブラリの1つです。

利用可能なCDNがあります。ここでは、UAParserを使用してブラウザを検出するためのコード例を含めました。

<!doctype html>
<html>
<head>
<script src="https://cdn.jsdelivr.net/npm/[email protected]/dist/ua-parser.min.js"></script>
<script type="text/javascript">
    var parser = new UAParser();
    var result = parser.getResult();
    console.log(result.browser);     // {name: "Chromium", version: "15.0.874.106"}
</script>
</head>
<body>
</body>
</html>

これで、result.browserの値を使用して、ページを条件付きでプログラムすることができます。

ソースチュートリアル: JavaScriptを使用してブラウザ、エンジン、OS、CPU、およびデバイスを検出する方法

2
Luzan Baral
var BrowserDetect = {
        init: function () {
            this.browser = this.searchString(this.dataBrowser) || "Other";
            this.version = this.searchVersion(navigator.userAgent) || this.searchVersion(navigator.appVersion) || "Unknown";
        },
        searchString: function (data) {
            for (var i = 0; i < data.length; i++) {
                var dataString = data[i].string;
                this.versionSearchString = data[i].subString;

                if (dataString.indexOf(data[i].subString) !== -1) {
                    return data[i].identity;
                }
            }
        },
        searchVersion: function (dataString) {
            var index = dataString.indexOf(this.versionSearchString);
            if (index === -1) {
                return;
            }

            var rv = dataString.indexOf("rv:");
            if (this.versionSearchString === "Trident" && rv !== -1) {
                return parseFloat(dataString.substring(rv + 3));
            } else {
                return parseFloat(dataString.substring(index + this.versionSearchString.length + 1));
            }
        },

        dataBrowser: [
            {string: navigator.userAgent, subString: "Edge", identity: "MS Edge"},
            {string: navigator.userAgent, subString: "MSIE", identity: "Explorer"},
            {string: navigator.userAgent, subString: "Trident", identity: "Explorer"},
            {string: navigator.userAgent, subString: "Firefox", identity: "Firefox"},
            {string: navigator.userAgent, subString: "Opera", identity: "Opera"},  
            {string: navigator.userAgent, subString: "OPR", identity: "Opera"},  

            {string: navigator.userAgent, subString: "Chrome", identity: "Chrome"}, 
            {string: navigator.userAgent, subString: "Safari", identity: "Safari"}       
        ]
    };

    BrowserDetect.init();


    var bv= BrowserDetect.browser;
    if( bv == "Chrome"){
        $("body").addClass("chrome");
    }
    else if(bv == "MS Edge"){
     $("body").addClass("Edge");
    }
    else if(bv == "Explorer"){
     $("body").addClass("ie");
    }
    else if(bv == "Firefox"){
     $("body").addClass("Firefox");
    }


$(".relative").click(function(){
$(".oc").toggle('slide', { direction: 'left', mode: 'show' }, 500);
$(".oc1").css({
   'width' : '100%',
   'margin-left' : '0px',
   });
});
1
neel upadhyay

これ 2016年のRobの元の答えとPilauの更新の両方を組み合わせたものです。

    var isOpera = !!window.opera || navigator.userAgent.indexOf(' OPR/') >= 0;
    // Opera 8.0+ (UA detection to detect Blink/v8-powered Opera)
var isFirefox = typeof InstallTrigger !== 'undefined';   // Firefox 1.0+
var isSafari = Object.prototype.toString.call(window.HTMLElement).indexOf('Constructor') > 0;
    // At least Safari 3+: "[object HTMLElementConstructor]"
var isChrome = !!window.chrome && !isOpera;              // Chrome 1+
var isIE = /*@[email protected]*/false || !!document.documentMode;
// Edge 20+
var isEdge = !isIE && !!window.StyleMedia;
// Chrome 1+
var output = 'Detecting browsers by ducktyping:<hr>';
output += 'isFirefox: ' + isFirefox + '<br>';
output += 'isChrome: ' + isChrome + '<br>';
output += 'isSafari: ' + isSafari + '<br>';
output += 'isOpera: ' + isOpera + '<br>';
output += 'isIE: ' + isIE + '<br>';
output += 'isIE Edge: ' + isEdge + '<br>';
document.body.innerHTML = output;
0
Joe Borg

ここでは、どのブラウザが動作しているのかがわかります。

function isValidBrowser(navigator){

            var isChrome =  navigator.indexOf('chrome'),
            isFireFox= navigator.indexOf('firefox'),
            isIE = navigator.indexOf('trident') ,
            isValidChromeVer = parseInt(navigator.substring(isChrome+7, isChrome+8)) >= 4,
            isValidFireForVer = parseInt(navigator.substring(isFireFox+8, isFireFox+9)) >= 3,
            isValidIEVer = parseInt(navigator.substring(isIE+8, isIE+9)) >= 7;

            if((isChrome > -1 && isValidChromeVer){ console.log("Chrome Browser")}

            if(isFireFox > -1 && isValidFireForVer){ console.log("FireFox  Browser")}

            if(isIE > -1 && isValidIEVer)){ console.log("IE Browser")}


        }
0
Ajay
const isChrome = /Chrome/.test(navigator.userAgent)
const isFirefox = /Firefox/.test(navigator.userAgent)
0
Landaida

以下のutilメソッドを使用できます

utils.isIE = function () {
        var ver = navigator.userAgent;
        return ver.indexOf("MSIE") !== -1 || ver.indexOf("Trident") !== -1; // need to check for Trident for IE11
    };

    utils.isIE32 = function () {
        return (utils.isIE() && navigator.appVersion.indexOf('Win64') === -1);
    };

    utils.isChrome = function () {
        return (window.chrome);
    };

    utils.isFF64 = function () {
        var agent = navigator.userAgent;
        return (agent.indexOf('Win64') >= 0 && agent.indexOf('Firefox') >= 0);
    };

    utils.isFirefox = function () {
        return (navigator.userAgent.toLowerCase().indexOf('firefox') > -1);
    };
0
NPE