Android WebView如何判定網(wǎng)頁加載的錯誤
一 前言
在WebView加載網(wǎng)頁的過程中,有時會頁面加載不出來的情況,如下:
那么如何知道網(wǎng)頁加載錯誤了呢?
二 解決方法
webview.webViewClient = object : WebViewClient() { override fun onPageFinished(view: WebView?, url: String?) { super.onPageFinished(view, url) Log.d(TAG, "onPageFinished: ") } override fun onReceivedError( view: WebView?, request: WebResourceRequest?, error: WebResourceError? ) { super.onReceivedError(view, request, error) Log.d(TAG, "onReceivedError: request= " + request.json()) Log.d(TAG, "onReceivedError: error= " + error.json()) } } webview.loadUrl("https://www.baidu.com/")
request輸出:
{"a":{"a":"www.baidu.com/","b":true,… (Linux; Android 11; sdk_gphone_x86_arm Build/RSR1.200819.001.A1; wv) AppleWebKit/537.36 (KHTML, like Gecko) Version/4.0 Chrome/83.0.4103.106 Mobile Safari/537.36","Accept":"text/html,application/xhtml+xml,application/xml;q\u003d0.9,image/webp,image/apng,/;q\u003d0.8,application/signed-exchange;v\u003db3;q\u003d0.9","Upgrade-Insecure-Requests":"1"}}}
error輸出:
{"a":{"a":-1,"b":"net::ERR_CACHE_MISS"}}
/** * 需要注意的是:與老版本不同,新版本已經(jīng)針對所有的資源加載錯誤都會回調(diào)*(iframe, image, etc.), 不僅僅是加載的主頁面 */ public void onReceivedError(WebView view, WebResourceRequest request, WebResourceError error) { if (request.isForMainFrame()) { onReceivedError(view, error.getErrorCode(), error.getDescription().toString(), request.getUrl().toString()); } }
所以,通過以上監(jiān)聽,即可知道對應(yīng)的錯誤內(nèi)容,進而做相應(yīng)的業(yè)務(wù)處理。
三 常見的錯誤案例分析
1.錯誤:ERR_UNKNOWN_URL_SCHEME
復(fù)現(xiàn)條件:打開百度新聞資訊網(wǎng)頁,并點擊評論
載體 | 現(xiàn)象 |
---|---|
App內(nèi)置WebView | 報錯:ERR_UNKNOWN_URL_SCHEME |
UC、華為瀏覽器 | 停留在當(dāng)前頁面狀態(tài) |
Chrome瀏覽器 | 跳轉(zhuǎn)到百度APP內(nèi)部打開 |
來看一下頁面加載shouldOverrideUrlLoading 中回調(diào)request輸出:
{"a":{"a":"baiduboxapp://v1/easybrowse/hybrid?upgrade\u003d1\u0026type\u003dhybrid\u0026tpl_id\u003dlanding_app.html\u0026newbrowser\u003d1\u0026style\u003d%7B%22toolbaricons%22%3A%7B%22tids%22%3A%5B%224%22%2C%221%22%2C%222%22%2C%223%22%5D%2C%22menumode%22%3A%222%22%2C%22actionBarConfig%22%3A%7B%22extCase%22%3A%220%22%7D%7D%7D\u0026slog\u003d%7B%22from%22%3A%22feed%22%7D\u0026context\u003d%7B%22nid%22%3A%22news_9777178803801641010%22%7D\u0026ch_url\u003dhttps%3A%2F%2Fmbd.baidu.com%2Fnewspage%2Fdata%2Flandingreact%3FpageType%3D2%26nid%3Dnews_9777178803801641010%26uk%3D%26sourceFrom%3DlandingShare\u0026commentInfo\u003d%7B%22topic_id%22%3A1066000039731532%2C%22opentype%22%3A2%7D\u0026logargs\u003d%7B%22source%22%3A%221020283l%22%2C%22channel%22%3A%221020283m%22%7D\u0026needlog\u003d1","b":false,"c":true,"d":false,"e":"GET","f":{"Accept":"text/html,application/xhtml+xml,application/xml;q\u003d0.9,image/avif,image/webp,image/apng,/;q\u003d0.8,application/signed-exchange;v\u003db3;q\u003d0.9","Referer":"mbd.baidu.com/newspage/da…
可以發(fā)現(xiàn)協(xié)議不是http類開頭,而是百度自己定義的"baiduboxapp"。因此,不做處理,當(dāng)然是識別不了的。
2.實現(xiàn)UC、華為瀏覽器處理的效果——>無視
webview.webViewClient = object : WebViewClient() { override fun shouldOverrideUrlLoading( view: WebView?, request: WebResourceRequest? ): Boolean { Log.d(TAG, "shouldOverrideUrlLoading: ${request.json()}") if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP) { Log.d(TAG, "shouldOverrideUrlLoading: url->${request?.url}") if (view != null && request?.url?.toString() != null) { if (request.url.toString().startsWith("http")) { view.loadUrl(request.url.toString()) } return true }
3.如何實現(xiàn)Chrome瀏覽器處理的效果——>能跳轉(zhuǎn)
假定這是百度適配Chrome的效果,而不是Chrome主動去適配百度的代碼頁面,那么說明客戶端的WebView也是能做到這樣效果的。
基于此,我們來urldecode一下協(xié)議內(nèi)容來看看request有什么特殊:
baiduboxapp://v1/easybrowse/hybrid?upgrade=1&type=hybrid&tpl_id=landing_app.html&newbrowser=1&style={"toolbaricons":{"tids":["4","1","2","3"],"menumode":"2","actionBarConfig":{"extCase":"0"}}}&slog={"from":"feed"}&context={"nid":"news_9777178803801641010"}&ch_url=mbd.baidu.com/newspage/da…
整體來看,仍舊是符合URI規(guī)則的。這樣的話就可以考慮使用Intent處理的方式了。
webview.webViewClient = object : WebViewClient() { override fun shouldOverrideUrlLoading( view: WebView?, request: WebResourceRequest? ): Boolean { Log.d(TAG, "shouldOverrideUrlLoading: ${request.json()}") if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP) { Log.d(TAG, "shouldOverrideUrlLoading: url->${request?.url}") if (view != null && request?.url?.toString() != null) { if (request.url.toString().startsWith("http")) { view.loadUrl(request.url.toString()) } else { try { Log.d(TAG, "shouldOverrideUrlLoading: 開始跳轉(zhuǎn)") startActivity(Intent(Intent.ACTION_VIEW, request.url)) } catch (e: Exception) { Log.d(TAG, "shouldOverrideUrlLoading: ${e.json()}") } } } } return true }
運行查看效果如下:
從結(jié)果來看,能跳轉(zhuǎn)至百度的App,假定成立。 也就是針對非http協(xié)議地址的情況,可使用 startActivity(Intent(Intent.ACTION_VIEW, request.url)) 之類來進行協(xié)議內(nèi)容處理。
四 總結(jié)
最后,根據(jù)自家業(yè)務(wù)來定協(xié)議并處理,畢竟不是誰都愿意自家用戶跳出自家App的。
以上就是Android WebView如何判定網(wǎng)頁加載的錯誤的詳細(xì)內(nèi)容,更多關(guān)于Android WebView判定網(wǎng)頁加載的錯誤的資料請關(guān)注腳本之家其它相關(guān)文章!
- Android webView字體突然變小的原因及解決
- Android 解決WebView多進程崩潰的方法
- Android 中 WebView 的基本用法詳解
- 在Android環(huán)境下WebView中攔截所有請求并替換URL示例詳解
- 解決Android webview設(shè)置cookie和cookie丟失的問題
- Android 如何從零開始寫一款書籍閱讀器的示例
- Android實現(xiàn)閱讀進度記憶功能
- android閱讀器長按選擇文字功能實現(xiàn)代碼
- android仿新聞閱讀器菜單彈出效果實例(附源碼DEMO下載)
- Android實現(xiàn)閱讀APP平移翻頁效果
- Android編程實現(xiàn)小說閱讀器滑動效果的方法
- Android使用WebView實現(xiàn)離線閱讀功能
相關(guān)文章
Android自定義view仿微信刷新旋轉(zhuǎn)小風(fēng)車
這篇文章主要介紹了Android自定義view仿微信刷新旋轉(zhuǎn)小風(fēng)車,具有一定的參考價值,感興趣的小伙伴們可以參考一下2018-12-12淺談Android開發(fā)中ListView控件性能的一些優(yōu)化方法
這篇文章主要介紹了Android開發(fā)中ListView控件性能的一些優(yōu)化方法,需要的朋友可以參考下2016-01-01Android項目開發(fā)常用工具類LightTaskUtils源碼介紹
LightTaskUtils是一個輕量級的線程管理工具,本文通過實例代碼給大家詳細(xì)介紹Android項目開發(fā)常用工具類LightTaskUtils的相關(guān)知識,感興趣的朋友一起看看吧2022-06-06Android 老生常談LayoutInflater的新認(rèn)知
今天不想去聊一些Android的新功能,新特性之類的東西,特別想聊一聊這個老生常談的話題:LayoutInflater,感興趣的朋友來看看吧2022-03-03Compose自定義View實現(xiàn)繪制Rainbow運動三環(huán)效果
這篇文章主要為大家介紹了一個基于Compose自定義的一個Rainbow彩虹運動三環(huán),業(yè)務(wù)上類似于iWatch上的那個運動三環(huán),感興趣的小伙伴可以了解一下2023-02-02Android 抽屜效果的導(dǎo)航菜單實現(xiàn)代碼實例
本篇文章主要介紹了Android 抽屜效果的導(dǎo)航菜單實現(xiàn)代碼實例,這種側(cè)滑的抽屜效果的菜單很好,有興趣的可以了解一下。2016-12-12