WebView缓存图片到本地

webView.setWebViewClient(new WebViewClient(){
      @RequiresApi(api = Build.VERSION_CODES.LOLLIPOP)
      @Nullable
      @Override
      public WebResourceResponse shouldInterceptRequest(WebView view, WebResourceRequest request) {
        //如果有isCachePic属性
        if(params.containsKey("isCachePic")) {
          boolean isCachePic = (boolean) params.get("isCachePic");
          Log.d(TAG, "shouldInterceptRequest:我有回调 " + isCachePic);
          if(!isCachePic) {//如果不缓存,返回默认方式
            return super.shouldInterceptRequest(view, request);
          }
        }
        String picUrl = request.getUrl().toString();
        String[] urls = picUrl.split("/");
        if(urls.length > 1) {
          String fileName = picUrl.split("/")[urls.length - 1];
          String[] urlTypes = fileName.split("\\.");
          if(urlTypes.length > 1) {
            String urlType = urlTypes[urlTypes.length - 1];
            if (isPic(urlType)) {//解析出对应类型,如果是图片,那 么判断本地有没有
              if (context.getExternalFilesDir("") != null) {
                File myPicFile = new File(context.getExternalFilesDir("").getAbsoluteFile() + "/pics/" + fileName);
                if(myPicFile.exists()) {//如果文件存在,加载在网页
                  WebResourceResponse response = null;
                  try {
                    // 重新构造WebResourceResponse 将数据已流的方式传入
                    // 根据网络资源,找到本地资源的File
                    String micUlr = context.getExternalFilesDir("").getAbsoluteFile() + "/pics/" + fileName;
                    FileInputStream input = new FileInputStream(new File(micUlr));
                    response = new WebResourceResponse(MimeTypeMap.getSingleton().getMimeTypeFromExtension(MimeTypeMap.getFileExtensionFromUrl(micUlr)), "UTF-8", input);
                    Log.d(TAG, "shouldInterceptRequest: 正常加载中");
                  } catch (Exception e) {
                    Log.d(TAG, "shouldInterceptRequest: 加载中遇到问题" + e);
                    return super.shouldInterceptRequest(view, request);
                  }
                  return response;
                } else {//如果不存在就下载到本地
                  Log.d(TAG, "shouldInterceptRequest: 下载了图片");
                  PicSaveUtil.savePic(request.getUrl().toString(), context, PicSaveUtil.SAVE_PATH_TYPE_DATA, fileName);
                }
              } else {
                return super.shouldInterceptRequest(view, request);
              }
            }
          }

        }
        return super.shouldInterceptRequest(view, request);
      }
    });

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
WebView 缓存机制是指在访问网页时,WebView 会根据一定的规则将网页的一些数据(如 HTML、CSS、JS、图片等)保存到本地,以便下次访问同一网页时可以直接从本地读取数据,从而加快网页的加载速度。 WebView 缓存机制分为两种,分别是页面缓存和资源缓存。 1. 页面缓存 页面缓存是指将整个网页的 HTML、CSS、JS 等文件保存到本地,下次访问同一页面时可以直接从本地读取数据,从而加快页面的加载速度。页面缓存可以通过以下两种方式来实现: - 加载网页时启用缓存:在 WebView 中设置 setCacheMode() 方法,将其参数设置为 LOAD_CACHE_ELSE_NETWORK,即可启用页面缓存,并且在有网络连接时优先使用缓存数据。 - 清除缓存:可以通过 WebView 的 clearCache() 方法来清除页面缓存。 2. 资源缓存 资源缓存是指将网页中的图片、CSS、JS 等文件保存到本地,下次访问同一网页时可以直接从本地读取数据,从而加快网页的加载速度。资源缓存可以通过以下两种方式来实现: - 在 HTML 文件中设置缓存策略:可以通过设置 HTTP 头信息的方式来指定缓存策略,例如可以设置 Cache-Control、Expires 等字段来控制资源的缓存时间和缓存方式。 - 在 WebView 中设置缓存策略:可以通过 WebView 的 setAppCacheEnabled() 方法来启用资源缓存,并且可以通过 setAppCachePath() 方法来指定缓存文件的存储路径。 需要注意的是,WebView 缓存机制具体实现方式可能因版本和设备而异,因此在具体开发中需要仔细查阅相关文档和 API。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值