亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

用window.onerror捕獲并上報Js錯誤的方法

2019-11-20 10:40:34
字體:
來源:轉載
供稿:網友

前兩天有個2048游戲的用戶反饋說,打開游戲后不能玩兒,只有一個游戲面板,數字無法初始化,更無法移動,設備為iPhone 4S、iOS 5.1。嘗試從微信調起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之類的,都是瀏覽器標準草案的領跑者,這些個參數用就是了!

于是,可以寫一個小Demo來嘗試一下:

<!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("出錯了!");
用瀏覽器跑起來以后,打開console,基本就是這樣的了:

所以,這些數據都是可以做上報的了。
當然了,上面的error.js是和html頁面同域名下,如果error.js不在同域下,會是怎樣的?我們把error.js的引用改一下:

<script type="text/javascript" src="http://doitbegin.duapp.com/error.js"></script>
再來打開console,我們看到的是這樣的:

相當于window.onerror方法只捕獲到了一個errorMessage,而且是固定字符串,毫無參考價值。查了點資料(Webkit源碼),發現在瀏覽器實現script資源加載的地方,是進行了同源策略判斷的,如果是非同源資源,errorMessage就被寫死為“Script error”了:

好在script標簽有一個crossorigin屬性,設置它可以顯示比較詳細的錯誤信息,我們試著將script標簽改一下:

<script type="text/javascript" src="http://doitbegin.duapp.com/error.js" crossorigin></script>
刷新頁面,這個時候看到console中的輸出是這樣的:

出現這個error也不意外,既然設置了error.js為crossorigin,那error.js的HTTP Response Header也必須設置非同源可訪問。為了方便設置Header,把error.js做一個小改動,更名為:error-js.php。

<?php   header('Access-Control-Allow-Origin:*');   header('Content-type:text/javascript'); ?> throw new Error('出錯了'); 

此時刷新頁面,看到console中的輸出就已經正常了,所有信息都能正常捕獲:

OK,技術細節分析結束!我2048游戲靜態資源是放到靜態域(非同源)下的,所以要想通過window.onerror捕獲錯誤信息,就得按照上面的最后一種情況來操作了:

1、添加script的crossorigin屬性

2、配置一下服務器,設置靜態資源Javascript的Response為Access-Control-Allow-Origin

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
日本一区二区在线免费播放| 91免费精品国偷自产在线| 国产成人av网址| 粗暴蹂躏中文一区二区三区| 美女黄色丝袜一区| 精品国产91乱高清在线观看| 国产精品网址在线| 91精品视频在线看| 久久久精品一区二区| 欧美高清在线观看| 国产精品99免视看9| 亚洲福利小视频| 日韩精品在线观看一区二区| 午夜精品久久久久久久99热| 91亚洲精品在线观看| 国产亚洲精品久久久久动| 成人写真视频福利网| 国产精品久久久久久久久男| 国产精品吹潮在线观看| 在线视频精品一| 国内久久久精品| 欧美俄罗斯性视频| 欧美性xxxx18| 日韩电影免费观看中文字幕| 亚洲国产精品久久精品怡红院| 色妞在线综合亚洲欧美| 久久人人97超碰精品888| 亚洲精品欧美日韩| 欧美精品制服第一页| 亚洲欧洲视频在线| 欧美日韩精品在线视频| 久久久久九九九九| 91情侣偷在线精品国产| 亚洲a在线观看| 91在线观看免费观看| 国产日韩欧美在线视频观看| 亚洲精品美女在线| 亚洲欧美日韩另类| 亚洲欧美日韩中文视频| 中文字幕精品久久| 亚洲国产精品va在线| 国产精品91在线观看| 成人精品福利视频| 成人在线免费观看视视频| 国产精品久久999| 亚洲日本aⅴ片在线观看香蕉| 久久久久国产视频| 在线亚洲男人天堂| 国产精品va在线| 成年人精品视频| 国产人妖伪娘一区91| 97在线观看免费高清| 久久99青青精品免费观看| 九九精品视频在线观看| 欧美成人亚洲成人| 国产精品久久久av| 97视频国产在线| 日韩av在线免费播放| 中文字幕亚洲图片| 亚洲欧美日韩天堂| 国产亚洲综合久久| 欧美日韩午夜剧场| 久久精品在线视频| 国产精品美腿一区在线看| 亚洲美女精品成人在线视频| 久久久久99精品久久久久| 欧美日韩国产影院| 亚洲综合最新在线| 欧美激情视频在线| www日韩中文字幕在线看| 国产精品欧美激情在线播放| 91精品国产高清| 亚洲自拍偷拍一区| 久久免费视频在线观看| 日韩精品在线观看一区二区| 成人写真视频福利网| 欧美激情乱人伦| 中文字幕亚洲欧美在线| 亚洲一二在线观看| 日韩av第一页| 精品久久久免费| 亚洲天堂免费视频| 成人精品视频在线| 亚洲欧美制服中文字幕| 成人a在线观看| 日韩av在线免播放器| 欧美国产精品人人做人人爱| 日韩av在线看| 岛国av一区二区在线在线观看| 一区二区在线视频| 国内免费久久久久久久久久久| 激情久久av一区av二区av三区| 久久精品国产久精国产一老狼| 亚洲国产欧美在线成人app| 久久久av一区| 日韩精品在线免费观看视频| 国产精品网站大全| 韩国精品美女www爽爽爽视频| 国产婷婷色综合av蜜臀av| 91精品久久久久久久久久| 欧美激情xxxx性bbbb| 国模私拍一区二区三区| 久久免费少妇高潮久久精品99| 91精品国产色综合久久不卡98口| 中文字幕日韩精品在线| 欧美日产国产成人免费图片| 欧美人与性动交a欧美精品| 亚洲网址你懂得| 精品精品国产国产自在线| 亚洲精品国产福利| 欧美视频在线观看免费网址| 日韩精品免费在线视频观看| 国产精品一区二区性色av| 久久久成人精品| 精品视频在线播放色网色视频| 精品在线观看国产| 一本大道亚洲视频| 日韩中文字幕欧美| 国产精品劲爆视频| 精品无码久久久久久国产| 精品国产1区2区| 狠狠干狠狠久久| 91av中文字幕| 久久久久久久久久久亚洲| 91色琪琪电影亚洲精品久久| 亚洲精品国精品久久99热| 欧美一级视频免费在线观看| 日本亚洲精品在线观看| 26uuu日韩精品一区二区| 久久这里只有精品视频首页| 91久久精品视频| 亚洲欧洲高清在线| 91精品成人久久| 亚洲综合中文字幕68页| 欧美巨猛xxxx猛交黑人97人| 国语自产在线不卡| 欧美孕妇性xx| 97精品一区二区三区| 久久久久久免费精品| 国产精品69久久久久| 狠狠色噜噜狠狠狠狠97| 亚洲午夜未满十八勿入免费观看全集| 亚洲一区免费网站| 国产成人在线播放| 国产不卡在线观看| www.国产精品一二区| 川上优av一区二区线观看| 久久亚洲欧美日韩精品专区| 91精品中国老女人| 亚洲精品一二区| www国产精品视频| 麻豆精品精华液| 91po在线观看91精品国产性色| 日韩小视频网址| 色无极影院亚洲| 亚洲精品乱码久久久久久按摩观| 少妇高潮久久久久久潘金莲| 国产国语videosex另类| 亚洲精品日韩欧美| 色综合伊人色综合网| 亚洲人午夜精品| 日韩在线免费观看视频| 欧美精品久久久久久久久| 国产日韩精品一区二区|