关于HTTP的三种缓存头与缓存策略

本文详细介绍了HTTP1.0和HTTP1.1中的缓存策略,包括Expires、max-age、last-modified和Etag等机制。通过设置这些头部信息,可以实现强制缓存和协商缓存,优化前端性能并减少服务器负载。当客户端与服务器时间不一致时,Expires可能存在bug,而max-age单位为秒,能覆盖Expires。last-modified和Etag用于协商缓存,通过比较文件修改时间和内容哈希来决定是否更新资源。

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

http1.0 使用强制缓存

  • expires 强制缓存,单位是毫秒,如果客户端跟服务端时间不一致的情况下,会出现bug,前台无法感知
        // http 1.0 强制缓存方案,单位毫秒,如果客户端与服务端时间不一致就会出BUG
        res.setHeader("Expires", new Date(Date.now() + 10 * 1000).toUTCString())
    

http1.1 使用强制缓存与协商缓存

  • max-age 强制缓存,单位秒,会覆盖expires, 与协商缓存间使用更大的一个,前台可感知

      // http 1.1 强制缓存方案,与协商缓存 谁大听谁的,会覆盖Expires,单位秒
      res.setHeader("Cache-Control", "max-age=5")
    
  • last-modified 协商缓存 以后台设定的过期时间为准,前台无法感知

          // http 1.1 协商缓存 - 文件最终修改时间
          res.setHeader("Cache-Control", "no-cache")
          res.setHeader("last-modified", new Date().toUTCString())
          if (new Date(req.headers['if-modified-since']).getTime() + 3000 > Date.now()) {
            res.statusCode = 304
            res.end()
            return
          }
    
  • Etag 协商缓存 以文件的最终修改时间为准,前台无法感知

      // http 1.1 协商缓存 - 文件内容概览hash对比
      res.setHeader("Cache-Control", "no-cache")
      const crypto = require("crypto")
      const hash = crypto.createHash("sha1").update(content).digest("hex");
      res.setHeader("Etag", hash)
      if (req.headers["if-none-match"] === hash) {
        res.statusCode = 304
        res.end()
        return
      }
    
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

华洛

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值