http消息

Headers

HTTP协议的Header总共分为三种,分别是General HeadersEntity HeadersRequest/Response Headers 。目前最新的是基于HTTP/1.1的RFC2616,总共规定了47种头部字段。

General Headers

我把被Request和Response共享的Headers成为General Headers,具体有:

general-header = Cache-Control           
               | Connection       
               | Date             
               | Pragma           
               | Trailer          
               | Transfer-Encoding
               | Upgrade          
               | Via              
               | Warning
  • Cache -Control 指定请求和响应遵循的缓存机制,单向work

    Cache-Control:Public      可以被任何缓存所缓存
    
    Cache-Control:Private   内容只缓存到私有缓存中
    
    Cache-Control:no-cache    所有内容都不会被缓存
    
  • Connection 允许客户端和服务器指定与请求/响应连接有关的选项,keep-alive或者close

  • Date 提供日期和时间标志,说明报文是什么时间创建的

  • Pragma 头域用来包含实现特定的指令,最常用的是Pragma:no-cache,和 Cache-Control:no-cache 作用相同。用于Http/1.1之前的版本还没有实现 Cache-Control 字段

  • Trailer 如果报文采用了分块传输编码(chunked transfer encoding) 方式,就可以用这个首部列出位于报文拖挂(trailer)部分的首部集合

  • Transfer-Encoding 告知接收端为了保证报文的可靠传输,对报文采用了什么编码方式

  • Upgrade 给出了发送端可能想要”升级”使用的新版本和协议

  • Via 显示了报文经过的中间节点(代理,网嘎un)

Entity Headers

EntityHeaders主要用来描述消息体(message body)的一些元信息,具体有:

entity-header  = Allow                   
               | Content-Encoding 
               | Content-Language   
               | Content-Length   
               | Content-Location 
               | Content-MD5      
               | Content-Range    
               | Content-Type     
               | Expires          
               | Last-Modified

其中,以Content为前缀的Headers主要描述了消息体的结构、大小、编码等信息,Expires描述了Entity的过期时间,Last-Modified描述了消息的最后修改时间。

  • Content-Length:消息的内容长度
  • Content-Type:请求实体对应的MIME信息,application/x-www-form-urlencoded或者响应返回的MIME类型 Content-Type: text/html; charset=utf-8
  • Expires:浏览器会在指定时间前都使用本地缓存
  • Last-Modified:用于指示资源的最后修改时间
  • Content-Encoding:服务端支持的返回内容压缩编码类型
  • Content-Location:请求资源可替代的另一地址
  • Content-Range:在整个返回体中本部分的字节位置
  • Allow:允许的Method,只出现在状态码为405的响应消息中

Request Headers

Request-Line后面紧跟着的就是Headers。我们在上面已经介绍了General HeadersEntity Headers,下面便是Request Headers定义:

request-header = Accept                   
               | Accept-Charset    
               | Accept-Encoding   
               | Accept-Language   
               | Authorization     
               | Expect            
               | From              
               | Host              
               | If-Match          
               | If-Modified-Since 
               | If-None-Match     
               | If-Range          
               | If-Unmodified-Since
               | Max-Forwards       
               | Proxy-Authorization
               | Range              
               | Referer            
               | TE                 
               | User-Agent
               | Cookie

Request Headers 扮演的角色其实就是一个Request消息的调节器。需要注意的是若一个headers名称不在上面列表中,则默认当做Entity Headers的字段。在HTTP/1.1中,除了HOST字段,其他都是可选的。

前缀为 Accept 的headers

定义了客户端可以接受的媒介类型、语言和字符集等

  • Acceppt:text/html 代表浏览器可以接受的类型为 text/html,如果服务器无法返回html文档,会返回406。一般浏览器可以处理任何类型 Accept:*/*
  • Accept-Encoding: 浏览器申明自己接收的编码方法,通常指定压缩方法,是否支持压缩,支持什么压缩方法(compress,gzip)
  • Accpet-Language:申明自己接收的语言
  • Accept-Charset:申明接收的字符集,如utf-8

From, Host, Referer 和User-Agent

详细定义了客户端 如何初始化Request

  • User-Agent:告诉服务端,消息来源的OS和浏览器信息
  • Referer:请求的上下文信息,即上一个网页的地址
  • Host:必须的报文头字段,指定服务端的域名和端口号,通常从url解析
  • From:发出请求用户的email
  • Range:请求实体的一部分,指定范围 bytes=500-999

前缀为 If 的headers

规定了服务器只能返回符合这些描述的资源,若不符合, 则会返回304 Not Modified

  • If-Modified-Since :带上浏览器缓存页面的最后修改时间,Server端会对比实际文件的最后修改时间(Response消息的Last-Modified字段),一样则返回304,有修改返回200 OK和文件内容。客户端丢弃旧内容,缓存新内容。
  • If-None-Match :和Etag一起work,Client端再次请求同个资源时,带上上次Server端Response消息的Etag字段到If-None_Match中

Request-Line中的MethodGET,请求中不包含消息体,若为POST,则会包含消息体。

一个具体的Request消息实例:

GET /articles/http-basics HTTP/1.1
Host: www.articles.com
Connection: keep-alive
Cache-Control: no-cache
Pragma: no-cache
Accept: text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8

Response Headers

下面是response-header的定义:

response-header = Accept-Ranges
                | Age
                | ETag              
                | Location          
                | Proxy-Authenticate
                | Retry-After       
                | Server            
                | Vary              
                | WWW-Authenticate
                | Set-Cookie
  • Age: 表示消息自server生成到现在的时长,单位是秒
  • ETag: 是对Entity进行MD5 hash运算的值,用来检测更改
  • Location: 被重定向的URL
  • Server: 服务器标识
  • Vary:告诉下有代理是使用缓存还是从原始服务器请求
  • Set-Cookie:设置http Cookie
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 202,905评论 5 476
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,140评论 2 379
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 149,791评论 0 335
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,483评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,476评论 5 364
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,516评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,905评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,560评论 0 256
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,778评论 1 296
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,557评论 2 319
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,635评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,338评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,925评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,898评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,142评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,818评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,347评论 2 342

推荐阅读更多精彩内容