专栏首页Happy的分享你知道HTTP协议的ETag是干什么的吗?

你知道HTTP协议的ETag是干什么的吗?

前言

在HTTP1.1规范中,新增了一个HTTP头信息:ETag。对于普通开发者来说,可能平时真的不会接触到该HTTP头。平时接触不到或者说用得少,不代表这个请求头不重要。ETag使用得当,是可以减少服务器带宽压力的。

什么是ETag?

Etag是 Entity tag的缩写,可以理解为“被请求变量的实体值”,Etag是服务端的一个资源的标识,在 HTTP 响应头中将其传送到客户端。所谓的服务端资源可以是一个Web页面,也可以是JSON或XML等。服务器单独负责判断记号是什么及其含义,并在HTTP响应头中将其传送到客户端。比如,浏览器第一次请求一个资源的时候,服务端给予返回,并且返回了ETag: "50b1c1d4f775c61:df3" 这样的字样给浏览器,当浏览器再次请求这个资源的时候,浏览器会将If-None-Match: W/"50b1c1d4f775c61:df3" 传输给服务端,服务端拿到该ETAG,对比资源是否发生变化,如果资源未发生改变,则返回304HTTP状态码,不返回具体的资源。

Etag实际例子讲解

我们可以通过Etag来利用浏览器的缓存,降低我们服务器的带宽压力。这是可以提升服务端的性能的(数据传输上)。七牛云的文件存储,就用到了Etag的属性。现在,我请求七牛云上的一个资源:

可以通过它的响应头看到,返回了Etag字段给我们。Etag的值为Fpl1rXE-K20cYsLu89YTzUQ3ydDk。

再次刷新资源:

此时,HTTP的状态码变成了304,304状态码表示资源未改变。查看此次的HTTP请求头,如下:

可以看到,客户端在向服务端请求资源的时候,通过If-None-Match请求头带上了之前服务端返回的Etag的值。服务端收到第二次请求的时候,发现携带了If-None-Match字段,就重新计算服务器对应资源的Etag,如果二者匹配了,就认为资源没有发生变化,直接给客户端相应304,让客户端读取缓存中的数据。

总结

本文只是对Etag做一个概念性的讲解,并且结合了七牛云的对象存储的例子,分析了Etag缓存的流程。关于Etag,还有很多东西没有深入讲解,比如Etag是怎么计算的,Last-Modified/If-Modified-Since是什么,以及Etag实战等,这些在后续再做深入的讲解吧!

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • 【快学springboot】5.全局异常捕获,异常流处理业务逻辑

    上一篇文章说到,参数校验,往往需要和全局的异常拦截器来配套使用,使得返回的数据结构永远是保持一致的。参数异常springboot默认的返回结构:

    Happyjava
  • 还在用SimpleDateFormat?Java8都发布N年了,转LocalDateTime吧

    Java8发布,已有数年之久,但是发现很多人都还是坚持着用SimpleDateFormat和Date进行时间操作。SimpleDateFormat这个类不是线程...

    Happyjava
  • 为什么阿里规约手册要求谨慎使用Arrays.asList方法

    在开发中,有时候会碰到把多个参数,或者说把数组转成List的需求,通常我们会使用 Arrays.asList()方法。但是该方法在使用的过程中,稍有不慎就会出现...

    Happyjava
  • HTTP协议原理及实践

    HTTP是在应用层,基于传输层 0x1 低三层 物理层主要作用是定义物理设备如何传输数据 数据链路层在通信的实体间建立数据链路连接 网络层为数据在结...

    慕白
  • SpringMvc解决js跨域

    跨站 HTTP 请求(Cross-site HTTP request)是指发起请求的资源所在域不同于该请求所指向资源所在的域的 HTTP 请求。比如说...

    王念博客
  • 腾讯云安装iis的图文教程(领取腾讯云优惠券)

    不少企业已经开始使用腾讯云提供的云服务器、云数据库等服务了。一些刚刚开始使用腾讯云的网友,可能还不是很清楚腾讯云的具体操作方法,今天,我们就以腾讯云安装Inte...

    主机优惠教程
  • JS 活学活用正则表达式

    网上的帖子大多深浅不一,甚至有些前后矛盾,在下的文章都是学习过程中的总结,如果发现错误,欢迎留言指出~

    SHERlocked93
  • 软件工程师需要了解的网络知识:从铜线到HTTP(五)—— HTTP 和 HTTPS

    JohnLui:程序员,Swift Contributor,正在写《iOS 可视化编程与 Auto Layout》 HTTP 在以前的文章中,我大力推荐过《图解...

    前端黑板报
  • 002. Ansible部署及配置介绍

    提示:建议将PIP升级到最新:pip install --upgrade pip。

    木二
  • 【npm】如何在Atom中安装emmet和atom-beautify插件?

    为了提高编写HTML和CSS的速度,最近尝试着在Atom中安装emmet插件,下面谈谈安装成功的过程 1首先我尝试了网上教程中介绍最多的方法:打开Atom的引导...

    外婆的彭湖湾

扫码关注云+社区

领取腾讯云代金券