HTTP header中的 Cache-control
網頁的緩存是由HTTP消息頭中的“Cache-control”來控制的,常見的取值有private、no-cache、max-age、must-revalidate等,默認為private。其作用根據不同的重新瀏覽方式分為以下幾種情況:
(1) 打開新窗口
如果指定cache-control的值為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值為一個早已過去的時間,那么訪問此網時若重復在地址欄按回車,那么每次都會重復訪問。
(對于要求必須進行Authenticate才能訪問的敏感頁面,可以設置其為no-cache,這樣,每次瀏覽器動作都會要求刷新改頁面,在頁面表單上填充的內容也不會被保留。)
?
?
useful link:
http://www.javaeye.com/topic/294814
http://www.javaeye.com/topic/462476
總結
以上是生活随笔為你收集整理的HTTP header中的 Cache-control的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: [转]ArcGIS.Server.9.3
- 下一篇: mtu值修改