Android webViewの読み込みの成功と失敗のコールバック、リロード、onReceivedError、onReceivedSslError、onPageFinished、onProgressChanged

webViewは、さまざまなWebページ読み込みコールバックを提供します

1.onPageStarted        开始加载
2.onPageFinished       加载完成
3.onReceivedError      加载失败
4.onReceivedSslError   加载证书错误网页失败
5.onProgressChanged    网页加载进度

1.証明書エラーWebページをロードします

      www.baidu123.comのように、証明書エラーのあるWebページの場合、ウィンドウブラウザーで開いた後に次のプロンプトが表示されるWebページは、onReceivedErrorを呼び出しませんが、onReceivedSslErrorを呼び出します。

        ただし、onReceivedSslErrorはデフォルトでこのページをインターセプトして表示しないため、空白のページになります。インターセプトはスーパーで行われるため、これを実現する場合は、スーパーノートが必要です。

 @Override
 public void onReceivedSslError(WebView view, SslErrorHandler handler, SslError error) {
    //super.onReceivedSslError(view, handler, error);

 }

 

次に、webViewWebページのコールバックおよびリロード操作が実際に正常にロードされました

通常、Webページの読み込みに失敗したか成功したかを監視し、再読み込みが必要かどうかの処理やその他の処理を行う必要があります。

ただし、onPageFinishedコールバックは、Webページが正常に読み込まれたことを意味するものではありません。onPageFinishedは失敗しても呼び出され、onPageFinishedとonErrorの呼び出し順序が固定されていないため、判断できません。したがって、判断する場合は、onProgressChangedに進行状況をロードして判断する必要があります。これは、onErrorが呼び出された後に呼び出す必要があるため、onErrorで変数を設定する方法を使用して、onErrorが合格したかどうかを判断できます。

private boolean isWebViewloadError=false;//记录webView是否已经加载出错
mWebView.setWebChromeClient(new WebChromeClient(){
            @Override
            public void onProgressChanged(WebView view, int newProgress) {
                super.onProgressChanged(view, newProgress);
                if (newProgress == 100) {
                    //加载100%
                    Log.d(TAG, "onProgressChanged: " + "webView---100%");
                    if (!isWebViewloadError && View.VISIBLE == btnRetry.getVisibility()){
                        btnRetry.setVisibility(View.GONE);//重新加载按钮
                    }
                }
            }
        });

mWebView.setWebViewClient(new WebViewClient(){
            @Override
            public void onPageStarted(WebView view, String url, Bitmap favicon) {
                super.onPageStarted(view, url, favicon);
            }

            @Override
            public void onPageFinished(WebView view, String url) {
                super.onPageFinished(view, url);
              
            }

            @Override
            public void onReceivedError(WebView view, WebResourceRequest request, WebResourceError error) {
                super.onReceivedError(view, request, error);
                isWebViewloadError=true;
                btnRetry.setVisibility(View.VISIBLE);
            }

            @Override
            public void onReceivedSslError(WebView view, SslErrorHandler handler, SslError error) {
//                super.onReceivedSslError(view, handler, error);
                if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP) {
                    wvSmallNewLocalRecord.getSettings()
                            .setMixedContentMode(WebSettings.MIXED_CONTENT_ALWAYS_ALLOW);
                }
                handler.proceed();
                isWebViewloadError=true;
                btnRetry.setVisibility(View.VISIBLE);
            }

            @Override
            public boolean shouldOverrideUrlLoading(WebView view, String url) {
                view.loadUrl(url);
                return true;
            }
        });

注:onProgressChangedはmWebView.setWebChromeClientにあり、他のコールバックは.setWebViewClientにあります。

おすすめ

転載: blog.csdn.net/qq_37980878/article/details/109102519