ホームページ > ウェブフロントエンド > jsチュートリアル > window.onerror_javascript スキルを使用して JS エラーをキャプチャして報告する方法

window.onerror_javascript スキルを使用して JS エラーをキャプチャして報告する方法

WBOY
リリース: 2016-05-16 15:17:30
オリジナル
2279 人が閲覧しました

2 日前、2048 Game のユーザーから、ゲームパネルが 1 つしかなく、番号も初期化できず、デバイスも移動できなかったと報告がありました。そしてiOS 5.1。 WeChat から Safari を開こうとしましたが、それでも動作しませんでした。このゲームは HTML5 の機能を多く使用しているため、JS エラーが原因であると大まかに推定されています。しかし、そのような情報をどのように取得すればよいでしょうか?もちろん伝説の window.onerror です。

W3C から window.onerror に関するメソッド本体の紹介を見つけます:

これは基本的に、window.onerror メソッドについて次のように記述できることを意味します。

/** 
 * @param {String} errorMessage  错误信息 
 * @param {String} scriptURI   出错的文件 
 * @param {Long}  lineNumber   出错代码的行号 
 * @param {Long}  columnNumber  出错代码的列号 
 * @param {Object} errorObj    错误的详细信息,Anything 
 */
window.onerror = function(errorMessage, scriptURI, lineNumber,columnNumber,errorObj) { 
  // TODO 
}
ログイン後にコピー

ただし、使用する際は互換性の問題に注意する必要があります。Chrome などはブラウザ標準の草案の中ですべてのパラメータを備えているわけではないため、これらのパラメータを使用してください。

それでは、小さなデモを作成して試してみることができます:

<!DOCTYPE html> 
<html> 
<head> 
  <title>Js错误捕获</title> 
  <script type="text/javascript"> 
  /** 
   * @param {String} errorMessage  错误信息 
   * @param {String} scriptURI   出错的文件 
   * @param {Long}  lineNumber   出错代码的行号 
   * @param {Long}  columnNumber  出错代码的列号 
   * @param {Object} errorObj    错误的详细信息,Anything 
   */ 
  window.onerror = function(errorMessage, scriptURI, lineNumber,columnNumber,errorObj) { 
    console.log("错误信息:" , errorMessage); 
    console.log("出错文件:" , scriptURI); 
    console.log("出错行号:" , lineNumber); 
    console.log("出错列号:" , columnNumber); 
    console.log("错误详情:" , errorObj); 
  } 
  </script> 
</head> 
<body> 
  <script type="text/javascript" src="error.js"></script> 
</body> 
</html>
ログイン後にコピー

error.js ファイルの内容については、次のように記述します:

throw new Error("エラーが発生しました!")
ブラウザを実行した後、コンソールを開くと、基本的に次のように表示されます:

したがって、これらのデータは報告できます。
もちろん、上記の error.js は HTML ページと同じドメイン名にあります。error.js が同じドメイン名にない場合はどうなりますか?参照を error.js に変更しましょう:

もう一度コンソールを開くと、次のような内容が表示されます:

これは、errorMessage を 1 つだけキャプチャする window.onerror メソッドと同等であり、参照値を持たない固定文字列です。いくつかの情報(Webkitのソースコード)を確認したところ、ブラウザがスクリプトリソースのロードを実装する場合、オリジナル以外のリソースの場合、同一オリジンポリシーと判断され、errorMessageが「スクリプト エラー ”:

幸いなことに、script タグにはcrossorigin属性があり、それを設定すると、より詳細なエラー情報を表示できます:

ページを更新すると、コンソールに次のような出力が表示されます。

このエラーが発生するのは驚くべきことではありません。error.js はcrossorigin に設定されているため、error.js の HTTP 応答ヘッダーもオリジナル以外のソースからアクセスできるように設定する必要があります。ヘッダーの設定を容易にするために、error.js に小さな変更を加え、名前を error-js.php に変更します。


<&#63;php 
  header('Access-Control-Allow-Origin:*'); 
  header('Content-type:text/javascript'); 
&#63;> 
throw new Error('出错了'); 
ログイン後にコピー
この時点でページを更新すると、コンソールの出力が正常であり、すべての情報が正常に取得できることを確認します。

OK、技術的な詳細分析は終わりました。私の 2048 ゲームの静的リソースは静的ドメイン (同じソースではない) に配置されているため、window.onerror を通じてエラー情報を取得したい場合は、上記の最後の状況に従って操作する必要があります:

1. スクリプトのcrossorigin属性を追加します

2. サーバーを構成し、静的リソース Javascript の応答を Access-Control-Allow-Origin に設定します

関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート