android常用的缓存机制,Android WebView缓存机制总结

本文介绍了Android WebView的两种缓存机制:网页数据缓存和H5缓存。详细讲解了网页缓存的构成、缓存模式、清除及大小控制,并提到了H5缓存的设置、清除和大小控制。建议在有网络时使用LOAD_DEFAULT模式,无网络时使用LOAD_CACHE_ELSE_NETWORK模式。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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消息头的信息是:

0818b9ca8b590ca3270a3433284dd417.png

0818b9ca8b590ca3270a3433284dd417.png

总结:建议缓存策略为,判断是否有网络,有的话,使用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)

来设置缓存超过先前设置的最大容量时的策略。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值