zoukankan      html  css  js  c++  java
  • Android项目实战(五十六):获取WebView加载的url的请求错误码

    例如需求,我有一个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);
                        }
                    }
                }
            });    
  • 相关阅读:
    Data Flow ->> Slow Changing Dimension
    SQL Server ->> 生成Numbers辅助表
    Oracle ->> 查看分区表的每个分区的数据行分布情况
    SQL Server ->> 分区表上创建唯一分区索引
    Oracle ->> Oracle下查看实际执行计划的方法
    Oracle ->> Oracle下实现SQL Server的TOP + APPLY
    Oracle ->> 行转列, 列转行
    Oracle ->> Oracle下生成序列的方法
    linux find命令用法
    linux <<eof
  • 原文地址:https://www.cnblogs.com/xqxacm/p/11050436.html
Copyright © 2011-2022 走看看