首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Android项目实战(五十六):获取WebView加载的url的请求错误码

Android项目实战(五十六):获取WebView加载的url的请求错误码

作者头像
听着music睡
发布2019-06-21 14:55:35
1.2K0
发布2019-06-21 14:55:35
举报
文章被收录于专栏:Android干货Android干货

例如需求,我有一个WebView 加载一个url, 该url对应的网页本身自带下拉刷新 ,但是网页本身会有出现400 500 等异常请求错误码

这时候网页加载失败,页面本身的下拉是无法使用的,要求重新加载页面的话就需要在webview外层套一个android下拉控件(SwipeRefreshLayout)

这样导致下拉一定用的SwipeRefreshLayout的下拉

最终要求是如果页面加载成功的话,用页面本身的下拉,如果页面加载失败的话,用android下拉控件的下拉

--------------------------------------------------------------------------------------------------------------------------------------------

解决办法就是监听加载的url的请求的错误码,对SwipeRefreshLayout.setEnabled() 来控制是否允许下拉刷新

监听对应6.0+  6.0以下 分别为两种实现方式:

一、Android 6.0+ 判断请求码

        mWebView.setWebViewClient(new WebViewClient() {
            // .....
            
            @Override
            public void onReceivedHttpError(WebView view, WebResourceRequest request, WebResourceResponse errorResponse) {
                super.onReceivedHttpError(view, request, errorResponse);
                if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.M) {
                    if (errorResponse.getStatusCode() == 500 ){
                        refresh.setEnabled(true); // 放开下拉
                    }
                    LogUtils.i(TAG, "onReceivedHttpError:"+ errorResponse.getStatusCode());
                }
            }

        
        });

二、Android 6.0以下 判断请求码

        mWebView.setWebChromeClient(new WebChromeClient() {
            // .....

            @Override
            public void onReceivedTitle(WebView view, String title) {
                super.onReceivedTitle(view, title);
                if (Build.VERSION.SDK_INT < Build.VERSION_CODES.M) {
                    if (title.contains("500")) {
                        refresh.setEnabled(true);
                    }
                }
            }
        });    
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2019-06-20 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档