首页 > 其他 > 详细

缓存验证Last-Modified和Etag的使用

时间:2020-02-21 14:51:29      阅读:72      评论:0      收藏:0      [点我收藏+]

缓存工作示意图:

技术分享图片

 

 在http协议里面,数据的验证方式,主要有两个验证头:Last-Modified 和 Etag。

  Last-Modified 配合Last-Modified-Since或者If-Unmodified-Since使用,对比上次修改的时间验证资源是否需要更新。

  Etag 是一个更加严格的数据验证。数据签名[根据数据的内容进行签名,如果数据内容变了,Etag也会变],最典型

     的Etag数据签名就是hash计算。配合If-Match或者If-Non-Match使用,对比资源的签名判断是否使用缓存。

if (request.url === ‘/script.js‘) {
  response.writeHead(200, {
     ‘Content-Type‘: ‘text/javascript‘,
     ‘Cache-Control‘: ‘max-age=200000, no-cache‘,
     ‘Last-Modified‘: ‘123‘,
     ‘Etag‘: ‘777‘ 
  })
  const etag = request.headers[‘if-none-match‘]if (etag === ‘777‘) {
     response.writeHead(304, {   // 304 表示内容没有变
     ‘Content-Type‘: ‘text/javascript‘,
     ‘Cache-Control‘: ‘max-age=200000, no-cache‘,
     ‘Last-Modified‘: ‘123‘,
     ‘Etag‘: ‘777‘ 
  })
   response.end(‘‘) 
  } else {
       response.writeHead(200, {
       ‘Content-Type‘: ‘text/javascript‘,
       ‘Cache-Control‘: ‘max-age=200000, no-cache‘,
       ‘Last-Modified‘: ‘123‘,
       ‘Etag‘: ‘777‘ 
     })
  response.end(‘console.log("script loaded twice")‘)
}

 

缓存验证Last-Modified和Etag的使用

原文:https://www.cnblogs.com/ladybug7/p/12340974.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!