HTTP缓存相关

①基本流程

  1. 浏览器第一次请求数据时,服务器会将缓存标识(放在响应头中)和数据(响应主体)一同返回给客户端,客户端将数其备份到缓存数据库中;
  2. 当再次请求数据时,先根据catch-control或者expires判断本地缓存是否过期,若未过期,直接使用本地缓存;(强缓存)
  3. 如果本地缓存过期,并不意味着缓存不能用了,因为服务器的资源可能还没有变,可通过与服务器协商,判断本地缓存是否可用。(协商缓存)
  4. 浏览器会在请求头中设置缓存标识,服务器根据缓存标识进行校验,如果资源未改变,则返回304状态码,通知浏览器使用本地缓存。由于服务器只返回header部分,不需返回响应主体部分,所以请求时间和报文大小大大减少。
  5. 若资源发生了改变,则服务器返回带有新主体的200响应。

强缓存:直接使用本地缓存 不与服务器进行通信

协商缓存:返回304(未修改) 使用本地缓存 返回200服务器返回新资源

②控制缓存有效期的字段

expires(http1.0)

  • 缓存在浏览器过期的时间  可能存在时间误差

catch-control

  • no-catch: 不使用本地缓存,要与服务器进行协商
  • no-store: 禁用缓存
  • max-age:缓存在多少秒后失效  可以设置max-age = 0 使每次访问时都进行刷新
  • private:客户端可以缓存
  • public:客户端和服务端都可以缓存

③响应首部

lastModified

服务器最后一次修改的时间

ETag

资源的唯一标识

浏览器请求资源,服务器会在响应报文头中加入ETag标志,资源每次变更,Etag就会发生改变

④缓存再验证首部——浏览器请求首部字段

if-Modified-since:date

  • 自某个日期后资源发生了改变

if-None-Match:tag

  • 实体标签是否匹配

刷新对缓存的影响

第一次访问 200

按F5刷新(第二次访问) 304

按Ctrl+F5强制刷新 200

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 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、付费专栏及课程。

余额充值