溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Android WebView打開網(wǎng)頁一片空白的解決方法

發(fā)布時間:2020-09-27 00:47:45 來源:腳本之家 閱讀:1360 作者:xxq2dream 欄目:移動開發(fā)

問題描述:

  • 網(wǎng)頁鏈接是Https鏈接
  • 網(wǎng)頁鏈接在電腦的Chrome瀏覽器中打開正常
  • 網(wǎng)頁鏈接在手機的Chrome瀏覽器中打開正常
  • 網(wǎng)頁鏈接在IOS的App上打開正常
  • 網(wǎng)頁鏈接在Android App中打開一片空白,沒有任何提示

 問題原因

試了很多方法,最后發(fā)現(xiàn)是Https的證書有問題,由于網(wǎng)頁鏈接是客戶提供的,不知道證書是如何生成的,導致不被Android系統(tǒng)信任

問題的發(fā)現(xiàn)之旅

網(wǎng)頁鏈接在手機和電腦都能打開,所以想著網(wǎng)頁鏈接本身應該沒有問題。

debug網(wǎng)頁加載的過程也沒有發(fā)現(xiàn)問題

但是后來用UC瀏覽器打開以后發(fā)現(xiàn)加載的過程中會彈出提示:

Android WebView打開網(wǎng)頁一片空白的解決方法

出錯的提示

根據(jù)彈出的提示知道很可能是證書的問題,于是重新開始debug項目中的WebView

一般我們在初始化一個 WebView 時都有幾個固定的步驟,其中最重要的一步就是設置 WebViewClient

enWebview.setWebChromeClient(new WebChromeClient());
enWebview.setWebViewClient(new WebViewClient());

如果WebView加載因為證書的問題失敗,就會回調(diào) WebViewClient 的一個接口:

@Override
public void onReceivedSslError(final WebView view, final SslErrorHandler handler, SslError error) {
}

WebViewClient 默認會終止加載

public class WebViewClient {

  public void onReceivedSslError(WebView view, SslErrorHandler handler,SslError error) {
    //終止加載   
    handler.cancel();
  }
  ...
}

這個 handler 是一個 SslErrorHandler 接口

public class SslErrorHandler extends Handler {

  /**
   * @hide Only for use by WebViewProvider implementations.
   */
  @SystemApi
  public SslErrorHandler() {}

  /**
   * Proceed with the SSL certificate.
   */
  public void proceed() {}

  /**
   * Cancel this request and all pending requests for the WebView that had
   * the error.
   */
  public void cancel() {}
}

通過上面的注釋我們可以知道,調(diào)用 proceed 就是繼續(xù)利用當前證書加載,而 cancel 就是終止本次的所有請求。而上面 WebViewClient 顯然默認是終止所有請求了。

通過debug發(fā)現(xiàn), WebViewClient 在調(diào)用了上面的 SslErrorHandlercancel 方法以后,就馬上會回調(diào) onPageFinished 方法,不會回調(diào) onReceivedError ,所以也就不會展示自定義的加載錯誤頁面,結(jié)果就是一片空白了。

原因找到了,那怎么解決呢?

其實答案也已經(jīng)在上面給出了。我們直接覆寫 WebViewClientonReceivedSslError 方法,然后根據(jù)需要做些處理。比如彈出提示框告訴用戶當前證書有問題,是否繼續(xù)加載等。

public class MyWebViewClient {

  public void onReceivedSslError(WebView view, SslErrorHandler handler,SslError error) {
    //彈出提示框,讓用戶決定是否繼續(xù)加載
    //1.用戶選擇繼續(xù)加載
   // handler.proceed();
    //2.用戶取消
    //handler.cancel()
  }
  ...
}

總結(jié)

這個問題困擾了很久,剛剛開始想到可能是WebView兼容問題,因為印象里WebView有很多坑。但是同一個客戶提供的另一個Https的鏈接是正常的,而且之前沒有出現(xiàn)過這種情況,于是debug進去發(fā)現(xiàn)網(wǎng)頁鏈接正常傳入了就沒多想,就認為是沒問題了。還是"too young, too simple"??!

而且對 WebViewClientonReceivedSslError 也不熟悉,沒有想到這一層?,F(xiàn)如今基本上所有的網(wǎng)頁鏈接都是 Https 的了,我們以后在開發(fā)過程中還是要注意這個問題,在 onReceivedSslError 中提前做好處理。

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持億速云。

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI