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,在两种模式下都使用本地缓存数据。
大家可能不太清楚cache-control是什么。cache-control是指HTTP消息头中的Cache-control,常见取值有private、no-cache、max-age、must- revalidate等,默认为private。如果指定了max-age值,那么在此值内的时间里就不会重新访问服务器,例如:Cache-control: max-age=5(表示当访问此网页后的5秒内再次访问不会去服务器),max-age=0(表示向server 发送http 请求确认,该资源是否有修改 有的话 返回200 ,无的话 返回304)。Expires表示过期时间,设置为-1,表示立即过期。例如在浏览器中访问www.baidu.com,HTTP消息头的信息是:
总结:建议缓存策略为,判断是否有网络,有的话,使用LOAD_DEFAULT,无网络时,使用LOAD_CACHE_ELSE_NETWORK。
WebView webView=(WebView)findViewById(R.id.webView1);
WebSettings webSettings = webView.getSettings();
if(HttpUtil.isNetconnect())
webSettings.setCacheMode(WebSettings.LOAD_DEFAULT);
else
webSettings.setCacheMode(WebSettings.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)
来设置缓存超过先前设置的最大容量时的策略。