http协议缓存小结

缓存可以使用expire方式,设置到期时间,缓存的时间等于expire设置的时间减去当前的时间

也可以使用no-cache的方式进行缓存,当设置了no-cache的方式时,以no-cache的为准,expire不起作用

no-cache下常见的有no-store,no-cache,max-age,must-revalidate

no-store,不做缓存,每次返回200,拉取最新的资源

no-cache缓存一份,每次会读取最新的缓存内容

max-age配合must-revalidate使用,每次校验是否过期,如果没过期就读取缓存返回403,当设置了no-cache时,以no-cache为准

如何判断是否是最新的缓存

浏览器会记录上次http请求的last-modified和E-tag分别保存在本地的if-modified-since和if-none-match字段里,

发送请求时会带上,if-none-match和if-modified-since字段去服务端,和Etag和last-modified比较,

这两组也可以单独比较来判断缓存是否是最新

原文地址:https://www.cnblogs.com/windseek/p/9673838.html

时间: 2024-08-29 07:08:38

http协议缓存小结的相关文章

06 HTTP协议缓存控制

一:HTTP协议缓存控制 第1次请求时 200 ok 第2次请求时 304 Not Modified 未修改状态 解释: 在网络上,有一些缓存服务器,另, 浏览器自身也有缓存功能. 当我们第一次某图片时,正常下载图片,返回值200 基于一个前提--图片不会经常改动, 服务器在返回200的同时,还返回该图片的”签名”-- Etag  ,(签名可以理解图片的”指纹”). 当浏览再次访问该图片时,去服务器校验”指纹”, 如果图片没有变化,直接使用缓存中的图片,这样减轻了服务器负担. 二:抓包观察分析

Web缓存(一) - HTTP协议缓存

为什么要使用 Web 缓存 Web缓存一般分为浏览器缓存.代理服务器缓存以及网关缓存,本文主要讲的是 浏览器缓存,其它两种缓存大家自行去了解下. Web 缓存游走于服务器和客户端之间.这个服务器可能是源服务器(资源所驻留的服务器Add),数量可能是1个或多个:这个客户端也可能是1个或多个.Web 缓存就在服务器-客户端之间搞监控,监控请求,并且把请求输出的内容(例如html页面. 图片和文件)(统称为副本)另存一份:然后,如果下一个请求是相同的 URL,则直接请求保存的副本,而不是再次麻烦源服务

Http协议学习小结

本文是对这几天学习Http协议的基础知识的小结.内容包括了Http协议的原理,Http请求信息和Http响应信息以及Http协议状态码等内容. 1.Http协议的基本原理:有客户端向服务器发送请求,服务端对请求处理,对客户端进行相应.如下图所示. 图1 Http协议原理图 下面给出一个简单的请求和响应的示例代码: 客户端请求: GET / HTTP/1.1 Host: localhost Accept: text/html Accept-Language: en-us Accept-Encodi

TCP 协议学习小结

TCP 传输控制协议(Transmission Control Protocal): (1)TCP协议概括介绍: TCP协议是传输层的通信协议,有同学或许不理解了,IP是网络层的传输协议,这个传输层和网络层有什么区别呢?依我之见,网络层是用来寻找网络中的主机的,通过IP地址是可以锁定唯一主机的.我们通常的通信,是一个进程和另一个进程之间的通信,而进程是依附于主机的.故在一个进程到另一个进程的通信流程可简化为:进程A——主机A——主机B——进程B.而传输层协议就是实现主机A——主机B之间的通信的.

HTTP协议-缓存

HTTP 协议中,缓存更多关心的文档资源的再利用.其目的是减少数据传输,加快相应速度等等.而对于缓存采用的是什么方案,也就是存在内存中还是硬盘中之类的问题,就属于另外的内容了. 假设,我身在广东,但是我访问的服务器在北京,在服务器其他条件一致的时候,我访问北京的服务器所需要的速度,肯定没有访问广东的服务器快.此时如果先访问靠近我的服务器,先看看我需要的资源有没有相应的副本,有就直接返回:没有就到源服务器中请求.这样响应速度肯定会快很多,而且也减轻了源服务器的压力.当然这里还有‘缓存命中率’和‘字

基于memcached协议缓存层流量管理工具:Mcrouter

随着这次门户功能改造的深入,对各个功能模块有了更加深刻的认识,昨天在编码的过程中看到工程中引用的memcache缓存层流量管理工具:Mcrouter,结合原来了解到的Nginx在这里对这款Facebook的新产品的功能做一个介绍: 在去年的[email protected]大会和USENIX的USENIX的NSDI(联网系统设计和实现座谈会)上我们就提过会将缓存换成我们自主开发的分布式软件系统,我们称之为mcrouter(发音"mick-router").Mcrouter是一个memc

浏览器 HTTP 协议缓存机制详解

1.缓存的分类 2.浏览器缓存机制详解 2.1 HTML Meta标签控制缓存 2.2 HTTP头信息控制缓存 2.2.1 浏览器请求流程 2.2.2 几个重要概念解释 3.用户行为与缓存 4.Refer: https://www.cnblogs.com/520yang/articles/4807408.html 最近在准备优化日志请求时遇到了一些令人疑惑的问题,比如为什么响应头里出现了两个 cache control.为什么明明设置了 no cache 却还是发请求,为什么多次访问时有时请求里

android:LruCache缓存小结

原理: LruCache以键值对的形式,初始化时,需要设置缓存的大小K,超过这个大小的数据将会被清除.注意:清除的数据,是那些被先加入的数据.LruCache内部的数据结构是LinkedHashMap存储的.这样,LruCache就达到了缓存最近put的K个数据. 使用:[code] int cacheSize = 4 * 1024 * 1024; // 4MiB LruCache bitmapCache = new LruCache(cacheSize) { protected int siz

iOS开发网络篇—网络请求(HTTP协议)小结

1. 聊一下HTTP协议(协议的完整的通信过程) 2.通信过程 1> 请求 * 客户端 --> 服务器 * 请求的内容 a. 请求行(请求方法\HTTP协议\请求资源路径) b. 请求头(描述客户端的信息) c. 请求体(POST请求才需要有, 存放具体数据) 2> 响应 * 服务器 --> 客户端 * 响应的内容 a. 状态行(响应行, 状态码) b. 响应头(服务器信息, 返回数据的类型, 返回数据的长度) c. 实体内容(响应体, 返回给客户端的具体内容) 3.HTTP请求的