完美解决Android的WebView加载失败(404,500),显示的自定义视图

举报
再见孙悟空_ 发表于 2022/01/12 22:37:55 2022/01/12
【摘要】 完美解决Android的WebView加载失败(404,500),显示的自定义视图 好多朋友会在Android开发过程中遇到使用WebView加载html页面出现404,500等错误页面,也有好多人想自定义这个错误页面,但是在6.0之前,大家觉得自定义错误页面就不好处理了;  之前一直使用在WebView加载时,根据onRe...

完美解决Android的WebView加载失败(404,500),显示的自定义视图

好多朋友会在Android开发过程中遇到使用WebView加载html页面出现404,500等错误页面,也有好多人想自定义这个错误页面,但是在6.0之前,大家觉得自定义错误页面就不好处理了; 
之前一直使用在WebView加载时,根据onReceivedError() 判断网页是否加载成功,然后做相应的操作,但是最后发现,在一些情况下,html页面加载失败了,onReceivedError()方法却并没有执行。 
最后进过努力,想出了一个比较笨,但是我又觉得比较有效的方法。下面来给大家简单说一说: 
不知道大家发现没有,在所有的加载错误的html页面中,html的标题title可能都会包含错误信息,比如说“error”,这样的话我们就可以在这个html的标题title上做文章了。 
1.先给大家说说怎么获取这个html的标题title 
(1).Android应用开发的时候使用WebView这个组件的过程中可能会接触到WebViewClient与WebChromeClient,那么这两个类到底有什么不同呢 
WebViewClient主要帮助WebView处理各种通知、请求事件的,比如:


  
  1. onLoadResource
  2. onPageStart
  3. onPageFinish
  4. onReceiveError
  5. onReceivedHttpAuthRequest
  6. WebChromeClient主要辅助WebView处理Javascript的对话框、网站图标、网站title、加载进度等比如
  7. onCloseWindow(关闭WebView)
  8. onCreateWindow()
  9. onJsAlert (WebView上alert无效,需要定制WebChromeClient处理弹出)
  10. onJsPrompt
  11. onJsConfirm
  12. onProgressChanged
  13. onReceivedIcon
  14. onReceivedTitle
  15. 看上去他们有很多不同,实际使用的话,如果你的WebView只是用来处理一些html的页面内容,只用WebViewClient就行了,如果需要更丰富的处理效果,
  16. 比如JS、进度条等,就要用到WebChromeClient。
  17. (2).我们可以看到在 WebChromeClient 中有一个方法 onReceivedTitle() ,这个方法就是用来获取html页面的标题title的回调。

**2.我们在 WebChromeClient 中的 onReceivedTitle() 方法里判断html页面的标题中是否含有 “error” ,如果有,则证明html加载失败,设置加载失败的标记,让在 WebViewClient 的完成是回 
调的 onPageFinish() 方法里显示自定义的加载失败的页面**


  
  1. 代码如下:
  2. WebSettings webSettings = webView.getSettings();
  3. //设置WebView属性,能够执行Javascript脚本
  4. webSettings.setJavaScriptEnabled(true);
  5. //设置可以访问文件
  6. webSettings.setAllowFileAccess(true);
  7. webSettings.setCacheMode(WebSettings.LOAD_NO_CACHE);
  8. webView.setWebViewClient(new WebViewClient() {
  9. @Override
  10. public boolean shouldOverrideUrlLoading(WebView view, String url) {
  11. view.loadUrl(url);
  12. return true;
  13. }
  14. /**
  15. * 网页页面开始加载的时候,执行的回调方法
  16. * @param view
  17. * @param url
  18. * @param favicon
  19. */
  20. @Override
  21. public void onPageStarted(WebView view, String url, Bitmap favicon) {//网页页面开始加载的时候
  22. emptyView.setEmptyView(EmptyView.EMPTY_LOADING);//初始化一个显示正在加载的视图
  23. rl_detail.setVisibility(View.VISIBLE);
  24. rl_detail.removeAllViews();
  25. rl_detail.addView(emptyView);//在加载页面开始的时候显示一个正在加载的视图,
  26. webView.setEnabled(false);// 当加载网页的时候将网页进行隐藏
  27. ll_container_btn.setVisibility(View.GONE);
  28. btn_collect.setVisibility(View.GONE);
  29. super.onPageStarted(view, url, favicon);
  30. }
  31. /**
  32. * 网页加载结束的时候执行的回调方法
  33. * @param view
  34. * @param url
  35. */
  36. @Override
  37. public void onPageFinished(WebView view, String url) {//网页加载结束的时候
  38. if (!loadError) {//当网页加载成功的时候判断是否加载成功
  39. rl_detail.setVisibility(View.GONE);//加载成功的话,则隐藏掉显示正在加载的视图,显示加载了网页内容的WebView
  40. webView.setEnabled(true);
  41. ll_container_btn.setVisibility(View.VISIBLE);
  42. btn_collect.setVisibility(View.VISIBLE);
  43. } else { //加载失败的话,初始化页面加载失败的图,然后替换正在加载的视图页面
  44. rl_detail.removeAllViews();
  45. emptyView.setEmptyView(EmptyView.EMPTY_EMPTY, "您找的页面暂时走丢了...");
  46. rl_detail.addView(emptyView);
  47. }
  48. }
  49. /**
  50. * 页面加载错误时执行的方法,但是在6.0以下,有时候会不执行这个方法
  51. * @param view
  52. * @param errorCode
  53. * @param description
  54. * @param failingUrl
  55. */
  56. @Override
  57. public void onReceivedError(WebView view, int errorCode, String description, String failingUrl) {
  58. super.onReceivedError(view, errorCode, description, failingUrl);
  59. loadError = true;
  60. }
  61. });
  62. webView.setWebChromeClient(new WebChromeClient(){
  63. /**
  64. * 当WebView加载之后,返回 HTML 页面的标题 Title
  65. * @param view
  66. * @param title
  67. */
  68. @Override
  69. public void onReceivedTitle(WebView view, String title) {
  70. //判断标题 title 中是否包含有“error”字段,如果包含“error”字段,则设置加载失败,显示加载失败的视图
  71. if(!TextUtils.isEmpty(title)&&title.toLowerCase().contains("error")){
  72. loadError = true;
  73. }
  74. }
  75. });
  76. webView.loadUrl(url);

文章来源: wukong.blog.csdn.net,作者:再见孙悟空_,版权归原作者所有,如需转载,请联系作者。

原文链接:wukong.blog.csdn.net/article/details/53259655

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。