第六章、HTTP首部

<非常重要且恐怖的一章了>

HTTP报文=报文首部+(CR+LF)+报文实体

首部字段:
HTTP报文首部字段=(首部字段名:字段值)们
---类型*4:
  通用首部字段(请求&响应都可用);请求首部字段;响应首部字段;实体首部字段

-------------------------------------------------------通用首部字段-------------------------------------------------
Cache-Contorl:控制缓存行为,操作缓存的工作机制
  //Cache-Control:public/private/不缓存过期缓存:no-cache=Location|空(无参数表示可以使用缓存)
  /不缓存:no-store/对于公共缓存器,指定缓存期限和认证:s-maxage=秒数
  /接收缓存过期没超过指定时间的缓存:max-age=秒数
  /接收指定缓存时间内任有效的缓存:min-fresh=秒数
  /接收指定时间内的缓存,无论过期与否:max-stale=秒数
  /缓存服务器本地缓存了目标资源且不加载响应和有效性:only-if-cache
  /再次验证即将返回的缓存是否有效:must-ravalidate
  /要求缓存服务器收到客户端要求响应前检查返回的缓存:proxy-ravalidate
  /不允许改变缓存的媒体类型,防止缓存被压缩:no-transform
Connection:逐跳首部和连接的管理
  //逐跳首部/控制代理不再转发|转发前删除的首部字段:Connection:不再转发的首部字段
  //管理持久连接:Connection:close|Keep-Alive(非默认持久连接的HTTP版本指定)
Date:创建该报文的时间
Pragma:报文指令
  //客户端要求所有的中间服务器不返回缓存的资源:Pragma:no-cache
Trailer:首部一览,位于报文尾端
  //事先说明在报文主体中记录了哪些首部字段,该首部字段可应用在1.1版本分块传输编码时
Transfer-Encoding:报文主体的分块传输编码方式
Upgrace:协议的升级,用于检测HTTP协议是否可用高版本的协议通信,使用时需要再指定Connection:Upgrace
Via:经过的代理服务器的相关信息,用来追踪报文的转发,避免请求回环的发生
Warning:错误通知
  //通常会告知用户一些与缓存相关的错误
  //格式:Warning:[警告码][警告的主机:端口号]"[警告内容]"([日期时间])

----------------------------------------------请求首部字段---------------------------------------------------
Accept:用户代理可处理的媒体类型
  //通知服务器用户代理指定的<多个>媒体联系和媒体类型间的相对优先关系
  //Accept: type/subtype1(类型);q=0.3,type/subtype2,type/subtype3;q=0.8,type/subtype4;q=0.5
  //逗号分隔类型与类型,分号分隔类型名与权重q,不写权重默认为1.0最大,权重可精确到小数点后三位。
Accept-Charset:优先的字符集
  //通知服务器用户代理指定的<多个>字符集和字符集间的相对优先关系
  //优先级由权重q决定,格式与Accept相同
Accept-Encoding:优先的内容编码
  //通知服务器用户代理指定的<多个>内容编码和内容编码间的相对优先关系
  //优先级由权重q决定,格式与Accept相同,同时可用“*”表示指定任意的内容编码
  //内容编码例子:gzip;compress;deflate;identify
Accept-Language:优先的自然语言
  //通知服务器用户代理指定的<多个>自然语言和自然语言间的相对优先关系
  //优先级由权重q决定,格式与Accept相同
  //例子:Accept-Language:zh-ch,zh;q=0.7,en-us,en;q=0.3
Authorization:Web/用户代理的认证信息
Expect:期待服务器的特定行为
  //HTTP1.1:Expect:100-Continue(状态码100 Continue)
  //服务器无法理解时会返回状态码417 Expectation Failed
From:用户的电子邮箱地址
Host:请求资源所在服务器(必须包含)
************if-xxxx样式的请求首部字段称为条件请求,服务器收到附带条件的请求时,当判断条件为真时才会执行请求
If-Match:比较值是否等于E-Tag实体标记
  //此时服务器无法使用弱ETag,≠则返回412 Precondtion Failed
  //若If-Match:*,服务器会忽略ETag,只要资源存在即可处理请求
If-None-Match:比较值是否不等于实体标记(与If-Match相反)
If-Range:资源未更新时发送实体Byte的范围请求
  //字段值若是跟ETag值或更新日期时间一致,那么就返回为范围内资源,反之则返回全体资源
If-Modified-Since:比较资源是否更新/更新时间
  //如果在字段指定的日期时间后资源发生了更新,服务器就会接受请求
If-Unmodified-Since:比较资源是否更新/更新时间(与If-Modified-Since相反)
  //如果在字段指定的日期时间后资源未发生更新,服务器就会接受请求
Max-Forwards:最大的传输直跳数(十进制),经过一个代理是数值减一,数值为0时返回响应
Proxy-Authorization:代理服务器要求客户端的认证信息(服务器和客户端的使用Authorization)
Range:获取实体的字节范围请求
Referer:告知服务器请求的原始资源的URI
TE:传输编码的优先级
  //除了指定传输编码之外,还可以指定伴随trailer字段的分块传输编码的方式--TE:trailer
User-Agent:将创建请求的HTTP客户端(代理或浏览器)程序的信息传给服务器

----------------------------------------------------响应首部字段-------------------------------------------------
Accept-Ranges:是否接受字节范围请求
  //Accepy-Ranges:bytes(接受)|none(不接受)
Age:推算资源创建经过的时间/秒
ETag:资源的对应匹配信息
  //资源更新时,对应的ETag值也会更新
  //相同URI不同的语言版本的资源是不同的,此时他们的ETag也是不同的
  //强弱ETag:强---资源发生一点点细微变化ETag都会变化;弱--用于提示资源是否相同,只有根本性变化会影响它,这时,弱ETag会在字段值最开始处附加W,例子:ETag:W/"usagi-1234"
Location:令客户端重定向至URI
  //配合3开头的状态字提供重定向的URI,几乎所有浏览器都会强制访问已提示的重定向资源
Proxy-Authenticate:代理服务器对客户端的认证信息
Retry-After:再次发起请求的时机要求(字段值为日期时间)
Server:HTTP服务器的安装信息
Vary:代理服务器缓存的管理信息
WWW-Authenticate:服务器对客户端的认证信息

--------------------------------------------------实体首部字段---------------------------------------------------
Allow:资源可支持的HTTP方法
Content-Encoding:适用的内容编程方式(gzip;compress;daflate;indetity)
  //内容编码是指在不丢失实体信息的前提下所进行的压缩
Content-Language:自然语言(中/英)
Content-Length:实体主体的大小/字节
Content-Location:报文主体返回资源的对应URI
Content-MD5:报文摘要
  //是一串由MD5算法生成的值,目的在于检查报文主体在传输中是否保持完整
Content-Range:位置范围
  //告知客户点作为响应返回的实体哪个部分符合范围请求
Content-Type:媒体类型
Expires:过期的日期时间
  //在指定的时间之前,响应的缓存副本会一直被保存,超期之后缓存服务器会再次向源服务器请求资源
Last-Modified:资源最后的修改日期时间

---------------------------------------------------其他非HTTP1.1首部字段----------------------------------------
Cookie/Set-Cookie/Content-Disposition-------132-140未看

《图解HTTP》阅读笔记--第六章--HTTP首部的更多相关文章

  1. 深入理解 C 指针阅读笔记 -- 第六章

    Chapter6.h #ifndef __CHAPTER_6_ #define __CHAPTER_6_ /*<深入理解C指针>学习笔记 -- 第六章*/ typedef struct _ ...

  2. Hadoop阅读笔记(六)——洞悉Hadoop序列化机制Writable

    酒,是个好东西,前提要适量.今天参加了公司的年会,主题就是吃.喝.吹,除了那些天生话唠外,大部分人需要加点酒来作催化剂,让一个平时沉默寡言的码农也能成为一个喷子!在大家推杯换盏之际,难免一些画面浮现脑 ...

  3. Android群英传笔记——第六章:Android绘图机制与处理技巧

    Android群英传笔记--第六章:Android绘图机制与处理技巧 一直在情调,时间都是可以自己调节的,不然世界上哪有这么多牛X的人 今天就开始读第六章了,算日子也刚好一个月了,一个月就读一半,这效 ...

  4. JVM学习笔记-第六章-类文件结构

    JVM学习笔记-第六章-类文件结构 6.3 Class类文件的结构 本章中,笔者只是通俗地将任意一个有效的类或接口锁应当满足的格式称为"Class文件格式",实际上它完全不需要以磁 ...

  5. 第六章 HTTP首部

    第六章 HTTP首部 HTTP首部包括:请求行<方法,URI,版本号>/响应行<版本,状态码>.请求/响应首部字段.通用首部字段.实体首部字段 1.HTTP首部字段 HTTP首 ...

  6. 《图解HTTP》阅读笔记--第十一章针对web的攻击技术

    第十一章.针对WEB的攻击技术 ----<图解HTTP>阅读笔记攻击目标---Web简单的HTTP协议本身并不存在安全性 问题,协议本身并不会成为被攻击的对象,应用HTTP的服务器和客户端 ...

  7. 《Microsoft Sql server 2008 Internals》读书笔记--第六章Indexes:Internals and Management(1)

    <Microsoft Sql server 2008 Internals>索引文件夹: <Microsoft Sql server 2008 Internals>读书笔记--文 ...

  8. C Primer Plus 学习笔记 -- 前六章

    记录自己学习C Primer Plus的学习笔记 第一章 C语言高效在于C语言通常是汇编语言才具有的微调控能力设计的一系列内部指令 C不是面向对象编程 编译器把源代码转化成中间代码,链接器把中间代码和 ...

  9. C primer plus 读书笔记第六章和第七章

    这两章的标题是C控制语句:循环以及C控制语句:分支和跳转.之所以一起讲,是因为这两章内容都是讲控制语句. 第六章的第一段示例代码 /* summing.c --对用户输入的整数求和 */ #inclu ...

随机推荐

  1. linux下面的挂载点讲解

    linux.unix这类操作系统将系统中的一切都作为文件来管理.在windows中我们常见的硬件设备.磁盘分区等,在linux.unix中都被视作文件,对设备.分区的访问就是读写对应的文件.挂载点实际 ...

  2. MySQL 学习四 SQL优化

    MySQL逻辑架构: 第一层:客户端层,连接处理,授权认证,安全等功能.   第二层:核心层,查询解析,分析,优化,缓存,内置函数(时间,数学,加密),存储过程,触发器,视图   第三层:存储引擎.负 ...

  3. 升级 AngularJS 至 Angular

    Victor Savkin 大神撰写了一系列文章详细介绍如何升级 AngularJS 应用: NgUpgrade in Depth Upgrade Shell Two Approaches to Up ...

  4. Ubuntu 下 ROS Kinetic 的安装

    安装环境为 Ubuntu 16.04 配置 Ubuntu 软件仓库 打开“设置”中的“软件和更新” 把 “restricted”.“universe” 和 “multiverse” 这三项勾上 勾完后 ...

  5. TypeError: 'append' called on an object that does not implement interface FormData 解决方法

    使用ajax提交form表单时,$("formId").serialize()不能提交type="file"类型的input,这个时候可以选择使用FormDat ...

  6. plupload的一些使用心得

    最近要做一个文件上传的东西 经过同事的推荐所以就选择了plupload,挺强大的 由于项目框架为改动后的MVC 刚一开始破费周折 不过最后总算是完成了 废话不多说了 粘出来代码给大家参考吧!文件包大家 ...

  7. zabbix启动web界面提示:Can't connect to local MySQL server through socket '/var/lib/mysql/mysql.sock' (2)

    问题 zabbix启动web界面提示: Can't connect to local MySQL server through socket '/var/lib/mysql/mysql.sock' ( ...

  8. css知多少(6)——选择器的优先级(转)

    css知多少(6)——选择器的优先级   1. 引言 上一节<css知多少(5)——选择器>最后提到,选择器类型过多将导致一些问题,是什么问题呢?咱们直接举例子说明. 上图中,css中的两 ...

  9. MyBatis配置Setting详细说明

    该表格转载自http://blog.csdn.net/summer_yuxia/article/details/53169227 setting是指定MyBatis的一些全局配置属性,这是MyBati ...

  10. String/StringBuilder 类 判断QQ号码

    1.1. 训练描述:[方法.String类]  一.需求说明:请用户输入一个“QQ号码”,我们来判断这个QQ号码是否正确. 要求:使用方法来完成判断功能. 1.2. 操作步骤描述 建立MainApp类 ...