转载原文地址: http://www.jquerycn.cn/a_14422

在session_start()之后,字符输出之前加上header("Cache-control: private");
网页的缓存是由HTTP消息头中的“Cache-control”来控制的,常见的取值有private、no-cache、max-age、must-revalidate等,默认为private。

其作用根据不同的重新浏览方式分为以下几种情况:

  1. 打开新窗口
    值为private、no-cache、must-revalidate,那么打开新窗口访问时都会重新访问服务器。而如果指定了max-age值,那么在此值内的时间里就不会重新访问服务器,例如:Cache-control: max-age=5(表示当访问此网页后的5秒内再次访问不会去服务器)
  2. 在地址栏回车

    • 值为private或must-revalidate则只有第一次访问时会访问服务器,以后就不再访问。
    • 值为no-cache,那么每次都会访问。
    • 值为max-age,则在过期之前不会重复访问。
  3. 按后退按扭

    • 值为private、must-revalidate、max-age,则不会重访问。
    • 值为no-cache,则每次都重复访问。
  4. 按刷新按扭

    • 无论为何值,都会重复访问
    • Cache-control值为“no-cache”时,访问此页面不会在Internet临时文章夹留下页面备份。
      另外,通过指定“Expires”值也会影响到缓存。例如,指定Expires值为一个早已过去的时间,那么访问此网时若重复在地址栏按回车,那么每次都会重复访问: Expires: Fri, 31 Dec 1999 16:00:00 GMT,比如:禁止页面在IE中缓存http响应消息头部设置:

      CacheControl = no-cache
      Pragma=no-cache
      Expires = -1
    • Expires,如果服务器上的网页经常变化,就把它设置为-1,表示立即过期。如果一个网页每天凌晨1点更新,可以把Expires设置为第二天的凌晨1点。
    • 当HTTP1.1服务器指定CacheControl = no-cache时,浏览器就不会缓存该网页。
    • 旧式 HTTP 1.0 服务器不能使用 Cache-Control 标题。
    • 所以为了向后兼容 HTTP 1.0 服务器,IE使用Pragma:no-cache 标题对 HTTP 提供特殊支持。
    • 如果客户端通过安全连接 (https://)与服务器通讯,且服务器在响应中返回 Pragma:no-cache 标题,则 Internet Explorer不会缓存此响应。注意:Pragma:no-cache 仅当在安全连接中使用时才防止缓存,如果在非安全页中使用,处理方式与 Expires:-1相同,该页将被缓存,但被标记为立即过期。
  5. Cache-Control消息头域说明

    • Cache-Control指定请求和响应遵循的缓存机制。在请求消息或响应消息中设置
    • Cache-Control并不会修改另一个消息处理过程中的缓存处理过程。请求时的缓存指令包括no-cache、no-store、max-age、 max-stale、min-fresh、only-if-cached,响应消息中的指令包括public、private、no-cache、no- store、no-transform、must-revalidate、proxy-revalidate、max-age。各个消息中的指令含义如 下:

      1. Public指示响应可被任何缓存区缓存。
      2. Private指示对于单个用户的整个或部分响应消息,不能被共享缓存处理。这允许服务器仅仅描述当用户的部分响应消息,此响应消息对于其他用户的请求无效。
    • no-cache指示请求或响应消息不能缓存
    • no-store用于防止重要的信息被无意的发布。在请求消息中发送将使得请求和响应消息都不使用缓存。
    • max-age指示客户机可以接收生存期不大于指定时间(以秒为单位)的响应。
    • min-fresh指示客户机可以接收响应时间小于当前时间加上指定时间的响应。
    • max-stale指示客户机可以接收超出超时期间的响应消息。如果指定max-stale消息的值,那么客户机可以接收超出超时期指定值之内的响应消息。

最新文章

  1. MAC显示文件夹路径
  2. linux mutext spinlock 性能分析
  3. 更新日志 - fir.im 新版优化上线
  4. winform listview控件
  5. 以下是关于Controller的一些Hint
  6. Debug的F5~F8用法
  7. wireshark使用详解
  8. 线性表实现简单vector
  9. 在android里用ExpandableListView实现二层和三层列表
  10. c#值类型与引用类型区别
  11. 使用flask_socketio实现客户端间即时通信
  12. [视频]K8飞刀 解密菜刀后门教程
  13. python 输出“Hello, world”
  14. 标准C++类std::string的内存共享和Copy-On-Write...
  15. 001-js-时间格式化
  16. jQuery显示SQL存储过程自定义异常信息
  17. React之设置元素的滚动条
  18. 开源项目MultiChoiceAdapter详解(六)——GridView和MultiChoiceBaseAdapter配合使用
  19. chapter02 三种决策树模型:单一决策树、随机森林、GBDT(梯度提升决策树) 预测泰坦尼克号乘客生还情况
  20. C# 的Timer 在javascript中的实现--基于Typescript

热门文章

  1. 线性反馈移位寄存器(LFSR)-非线性反馈移位寄存器的verilog实现(产生伪随机数)
  2. Linux基础篇一:Linux历史
  3. HTTP Status 500 - Request processing failed; nested exception is java.lang.IllegalArgumentException: Control character in cookie value or attribute.
  4. jquery时间控件
  5. jsonConfig用法
  6. ValidationUtil
  7. Linux下停止和启动redis
  8. leetcode第38题:报数
  9. mysql挖掘与探索------第2章 索引1-1
  10. 查看pip安装的包的位置