zoukankan      html  css  js  c++  java
  • android WebView缓存机制介绍

    当我们加载Html时候,会在我们data/应用package下生成database与cache两个文件夹:

    我们请求的Url记录是保存在webviewCache.db里,而url的内容是保存在webviewCache文件夹下.


    WebView中存在着两种缓存:网页数据缓存(存储打开过的页面及资源)、H5缓存(即AppCache)。

    一、网页缓存

    1、缓存构成

    /data/data/package_name/cache/
    /data/data/package_name/database/webview.db
    /data/data/package_name/database/webviewCache.db


    2、缓存模式(5种)

    LOAD_CACHE_ONLY:  不使用网络,只读取本地缓存数据

    LOAD_DEFAULT:  根据cache-control决定是否从网络上取数据。

    LOAD_CACHE_NORMAL: API level 17中已经废弃, 从API level 11开始作用同LOAD_DEFAULT模式

    LOAD_NO_CACHE: 不使用缓存,只从网络获取数据.

    LOAD_CACHE_ELSE_NETWORK,只要本地有,无论是否过期,或者no-cache,都使用缓存中的数据。
    如:www.taobao.com的cache-control为no-cache,在模式LOAD_DEFAULT下,无论如何都会从网络上取数据,如果没有网络,就会出现错误页面;在LOAD_CACHE_ELSE_NETWORK模式下,无论是否有网络,只要本地有缓存,都使用缓存。本地没有缓存时才从网络上获取。
    www.360.com.cn的cache-control为max-age=60,在两种模式下都使用本地缓存数据。


    总结:根据以上两种模式,建议缓存策略为,判断是否有网络,有的话,使用LOAD_DEFAULT,无网络时,使用LOAD_CACHE_ELSE_NETWORK。



    3、清除缓存

    clearCache(boolean)
    CacheManager.clear高版本中需要调用隐藏API


    4、控制大小

    无系统API支持。
    可选方式:定时统计缓存大小、按时间顺序删除缓存。


    二、H5缓存


    1、缓存构成

    根据setAppCachePath(String appCachePath)提供的路径,在H5使用缓存过程中生成的缓存文件。


    2、缓存模式

    无模式选择,通过setAppCacheEnabled(boolean flag)设置是否打开。默认关闭,即,H5的缓存无法使用。


    3、清除缓存

    找到调用setAppCachePath(String appCachePath)设置缓存的路径,把它下面的文件全部删除就OK了。


    4、控制大小

    通过setAppCacheMaxSize(long appCacheMaxSize)设置缓存最大容量,默认为Max Integer。
    同时,可能通过覆盖WebChromeClient.onReachedMaxAppCacheSize(long requiredStorage, long quota, WebStorage.QuotaUpdater quotaUpdater)来设置缓存超过先前设置的最大容量时的策略。


    这里又不得不拿IOS做一些比较:IOS中的webview的缓存机制可以拿到浏览过的网页的二进制流,这样下次就直接可以把流拿去显示

  • 相关阅读:
    [POJ1811]Prime Test
    Pollard-rho算法[因子分解算法]
    Miller-Rabin算法
    [POJ2886]Who Gets the Most Candies?
    Failed to connect to raw.githubusercontent.com port 443
    MAC安装flutter开发环境
    Jenkins自动化打包(Gitlab)并上传蒲公英
    Jenkins中插件下载失败的解决办法
    iOS开发~防止navigation多次push一个页面
    Jenkins 更新 jenkins.war的方法
  • 原文地址:https://www.cnblogs.com/lechance/p/4373208.html
Copyright © 2011-2022 走看看