• HTTP缓存学习


    1. 缓存控制Catch-Control


    • max-age:缓存有效期
    • public:允许其他用户读取缓存(公共缓冲服务器)
    • private:只允许特定用户读取缓存(公共缓冲服务器)
    • no-catch:不走强缓存,每次都请求服务器验证缓存是否可用(协商)
    • no-store:不走缓存,每次直接请求数据

    2. 缓存过期判断机制


    • 根据Catch-Controls-maxagemax-age判断,以s-maxage为例,若当前时间>缓存生成时间+s-maxage则表示已经过期(s-maxagemax-age作用都是设置缓存储存最大周期,s-maxage适用于多用户的公共缓存服务器)
    • 根据Expire比较,Expire代表一个绝对过期时间,若当前时间>Expire,代表缓存已经过期
    注: HTTP/1.1之前Expire优先级高于s-maxagemax-age,之后则相反

    3. 协商缓存


    根据判断机制判断出缓存过期后,进行协商缓存

    • Etag:实体标记,服务器资源每次更改都会引起资源Etag值的变化
    • Last-Modified:最后更新时间,服务器资源最后更新的时间
    • if-None-Match:放在请求头用于判断服务器对应值是否与传入值相同
    • if-Modified-Since:用于告诉服务器字段值早期更新时间,若与服务端不一致,则会处理请求
      当客户端第一次请求资源时,服务器会将所请求资源的EtagLast-Modified放在响应头交给客户端

    Etag验证

    当客户端第二次请求资源时,会将Etag作为if-None-Match的字段值,用于验证资源是否改变,若if-None-Match与服务端Etag不一致,说明服务端资源已经更改,服务器接受请求,返回新资源,否则返回304(此时响应头还会有Etag,即使没有变化)

    Last-Modified验证

    当客户端第二次请求资源时,将Last-Modified作为if-Modified-Since的字段值,提交给服务端,服务器会对比服务器资源的Last-Modified与客户端传入的if-Modified-Since,如果不一致说明资源更改时间不一致,有更新,返回新资源,否则返回304(响应头不会添加Last-Modified

    EtagLast-Modified比较

    • Etag比对的是资源内容,可以检测到细微改变
    • Last-Modified比对的是资源文件修改时间,在内容未更改仅仅是修改时间更改的情况下也会引起重新发送数据,检查粒度是秒级,秒级以下的更改无法判断

    由此可以看出,Etag能够更加精准控制缓存,两者可以同时只有,服务器优先验证Etag

  • 相关阅读:
    js:delete 操作符
    ActiveReports 代码控制报表连续打印
    ActiveReports 打印条码无法设置纸张大小?
    《JavaScript高级程序设计》读书笔记之一:几个与原始类型等价的引用类型的常用方法和属性
    js:字符串类型快速转化成数字类型和数字类型快速转化为字符串类型
    js:for...in 语句(JavaScript For...In Statement)
    Internet Explorer Developer Toolbar
    javascript 定义对象的方法
    关于 输入框输入一定数以后跳转的问题
    javascript 关于弹出关闭的例子
  • 原文地址:https://www.cnblogs.com/aeipyuan/p/12990167.html
Copyright © 2020-2023  润新知