詳解Android WebView監(jiān)聽console錯(cuò)誤信息
根據(jù)需求,我們要拿到h5的錯(cuò)誤信息,并將error信息進(jìn)行上報(bào)。查詢了下Android WebView的API發(fā)現(xiàn)了WebChromeClient這個(gè)方法可以滿足要求:
@Override public boolean onConsoleMessage(ConsoleMessage consoleMessage) { //獲取log的級別 switch (consoleMessage.messageLevel()){ case ERROR://將error信息上報(bào)到服務(wù)端 LogUtil.logE('webview==',consoleMessage.message()+' level='+ consoleMessage.messageLevel()); LogUtil.uploadH5Error(consoleMessage.message()); break; } return super.onConsoleMessage(consoleMessage);}
這個(gè)方法的作用就是* Report a JavaScript console message to the host application.,就是說這個(gè)方法可以攔截JavaScript的console信息,就跟在瀏覽器里查看一樣;對于Android來說,在Android studio 的logcat里面就就可以查看,比如我讓h5隨便弄個(gè)undefined錯(cuò)誤,然后重寫了js的log方法logcat輸出如下:

從輸出信息我們可以看到可以捕獲到行號,錯(cuò)誤信息,錯(cuò)誤的URL。這些信息都在ConsoleMessage對象里。 其代碼如下:

可以看出ConsoleMessage里面也有l(wèi)og級別,我們只需要將error級別的日志上報(bào)即可。
到此這篇關(guān)于Android WebView監(jiān)聽console錯(cuò)誤信息的文章就介紹到這了,更多相關(guān)Android WebView console錯(cuò)誤信息內(nèi)容請搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!
相關(guān)文章:
1. PHP終止腳本執(zhí)行的實(shí)例代碼2. 資深程序員:給Python軟件開發(fā)測試的25個(gè)忠告!3. python GUI庫圖形界面開發(fā)之PyQt5信號與槽機(jī)制、自定義信號基礎(chǔ)介紹4. Python開發(fā)環(huán)境怎么安裝5. Android 開發(fā)使用PopupWindow實(shí)現(xiàn)彈出警告框的復(fù)用類示例6. PHP開發(fā)框架的現(xiàn)狀和展望7. Android自定義Dialog框樣式8. PHP應(yīng)用分頁顯示制作詳細(xì)講解9. vue項(xiàng)目如何監(jiān)聽localStorage或sessionStorage的變化10. 一文讀懂Spring Cloud-Hystrix

網(wǎng)公網(wǎng)安備