1. 状态码:status code

1xxx:信息--请求被接收,继续下一步处理
 
2xxx:成功--请求行为被成功接收、理解和接受
 
3xxx:重定向--需要进一步的处理来完成请求
 
4xxx:客户端错误--请求包含错误的语法或者无法处理
 
5xxx:服务器错误--服务器无法处理合理的请求
 
 
100:CONTINUE 请求已接受,请继续发送信息,
 
101:Switch Protocal 协议转换,Upgrade 更先进的协议
 
200:OK GET 请求的资源对象;HEAD 对应请求资源的 entity-header 字段,不包含消息体;POST;请求行为的结果消息体;TRACE: 包含请求消息的消息体
 
201:Created 请求处理完成,资源已创建。
 
202:(Accepted)请求接收,处理还未完成,使得客户端及时了解资源请求状况,监视进度
 
203:
 
204:No Content 请求处理完成,但是不需要返回消息体
 
205:Reset Content 服务器完成请求,客户端刷新view
 
206:Partial Content 回复包含 Range或者If-Range请求头的GET请求
 
300:Mutiple Choices,服务器返回包含可用资源列表的消息体供客户端选择,如果客户端一开始就有倾向,则需要在头信息 Location添加特殊URI信息,客户端可以使用此信息自动选择。
 
301:Move Permanently,请求资源永久重定向,服务器使用Location返回重定向URI,对于GET HEAD请求,客户端不能自动重定向请求
 
302:Found 临时重定向,其它同上
 
303:See Other,资源在其它路径,可以通过GET获取
 
304:Not Modify 客户端已缓存资源,并且服务器端为左更改,缓存可以继续使用
 
305:Use Proxy 必须使用代理反问资源,服务器使用Location返回代理资源路径
 
306:Unused 未使用
 
307:Temporary Redirect
 
400:Bad Request,语法错误,服务器无法处理
 
401:Unauthorized 未授权,需要请求信息包含 authentication: basic digest access authentication
 
402:未使用
 
403:Forbidden,理解请求,拒绝服务,
 
404:Not Found
 
405:Method Not Allowed 请求方法不允许,服务器返回allow:允许的方法头信息
 
406:Not Acceptable  无法满足所有的消息头要求;返回消息体,包含所能提供的资源表现形式的列表,允许用户手动进行选择。
 
407:Proxy Authentication Required 代理权限验证,代理返回Proxy-Authenticate:验证说明,客户端重新发送带有Proxy-Authorization头信息
 
408:Request Time Out:
 
409:Conflict 请求资源冲突,例如多客户段请求修改MVVC控制的资源
 
。。。
 
500:Internal Server Error 服务器内部错误
 
501:Not Implementd 未实现能完成请求的方法功能
 
502:Bad Gateway 网关错误
 
503:Service Unavalible 当前服务不可用,可以择机retry
 
504:Gateway Timeout
 
505:Http Version Not Supported
 
entity-body:= Content-Encoding(Content-Type(data))
 
没有默认的encoding
 

2. 消息类型:content-type

任何http/1.1消息,如果包含消息体,则必须在消息头上包含一个Content-type,如果未设置,接收方会尝试通过检查消息内容,或者根据url携带的资源名称扩展来判断消息类型。如果还是无法确定,则使用application/octet-stream

3. 消息长度:entity-length

entity-length 是指编码之前的消息体长度,transfer-length 是指编码之后的消息体长度。
 

4. 长连接:keepalive

  • 持久化的http连接:http/1.1产生并默认
  • 频繁的tcp连接:增加性能开销。网络负担,内存消耗及时效性浪费
  • 节省端点(routers、hosts(clients、servers、proxies、gateways、tunnels、caches))cpu消耗
  • TCP control block memory used saved in hosts 节省主机TCP控制块内存消耗
  • pipelined操作,可以连续发送请求,而不必等待每一个回复。较小的elapsed time,使的单条TCP连接使用更有效率。
  • 减少频繁tcp握手连接,关闭产生的报文对网络的影响,因为不需要每一次的握手建立连接,减少了后续请求延迟。
  • 错误信息反馈不需要关闭当前TCP连接,再重新打开连接发送。发送错误信息后,连接依然维持
  • Connection:close 关闭连接,如果客户端指向发送单次请求,然后关闭连接,则需要在头信息里添加Connection:close。
  • 持久化连接发送的消息必须写到消息长度

5. Pipeline:客户端顺序发送请求,服务器按相同的顺序发送回复。

  • pipeline消息只能建立在持久TCP连接上,并做好重发准备,如果服务器没有回复pipeline请求的所有消息,客户端也应该重发请求。
  • pipeline的请求必须是幂等的,

6. proxy:

  • 对于代理,是分别和客户端和服务器建立了持久的连接,
  • 客户端,服务器,代理需要能够从不同的连接关闭事件中恢复。
  • 客户端需要重新打开连接,发送丢失的请求
  • 服务端一个连接需要至少回复一个请求,在回复所有请求前,不应该关闭连接
  • 客户端需要限制同时连接到服务器的请求N,一般限制为N=2个;代理则至多使用2N个连接
 
TCP流控制机制 flow control mechanism
 

7. 监控连接错误信息:

  • 当接收到错误信息后,应该立马终止消息传送;
  • 当以 chunk 编码发送时,应该发送一条长度为0的chunk,结合 empty trailer 来告知接收方消息的结束。
  • 当Content-length 头信息存在时,客户端需要立马关闭连接
 

8. status:100

 
作用:用作客户端在发送消息体之前,请求判断消息接收端是否愿意接收消息(根据请求头信息)
 
操作:客户端需发送  Expect: 100-continue
 
附注:如果不需要发送消息体,则不要发送此头信息
 
服务器端接收到包含  Expect: 100-continue 头信息的请求时,需要立马回复status 100,并继续读取消息,或者回复最终的消息状态码(之后可能终止连接或者接受并丢弃消息)。
 
一般来说,服务器不要回复100给未发送Expect: 100-continue头信息的请求,及来自http/1.0版本的请求。
例外:
http/1.1为了compatibility with RFC2068,对于put、post请求,服务器会添加100 回复,以减少内置等待100客户端的处理延迟。
 
 
服务器:
 
服务器在接收到部分或者全部消息体时,可能会回复100。
 
服务器发送完100后,也必须最终发送最终处理状态。
 
服务器接收完消息前,不能关闭连接
 
代理:
 
代理在能够确定转发服务器为http/1.1,或者不知道转发服务器协议版本时,必须完整转发包包含Expect: 100-continue头信息的请求。
 
代理在能够确定转发服务器为http/1.0时,不能转发此请求,并回复417状态(expection  field)
 
代理应该缓存最近转发的服务器的协议版本信息。
 
代理不应该想使用http/1.0版本发送的未带Expect: 100-continue头信息的请求回复100状态码;
 
 

9. http/1.1 host 头信息需求。

Options:为了在请求前获取url请求路径上的相关信息
 
200回复,需要在头信息中包含所有的服务器端对于请求资源支持的信息;Content-length需求。
 
Max-Forwards:指定到达请求脸上的某个代理,获取相应的信息,当收到options请求时,代理需要检查Max-Forwards字段,当为0时,不能在转发此消息,而需要返回自己的通讯选项信息。当大于0,直接转发请求。
 
不能中途添加此头信息。
 
 
“conditional GET” if the request message includes an IfModified-Since, If-Unmodified-Since, If-Match, If-None-Match, or If-Range header field:
 
传送满足头信息if条件的资源,减少网路传输
 
“partial GET” if the request message includes a Range header field.
 
获取部分资源请求。
 
Head方法除了服务器回复信息不能包含消息体外,其它与GET一样
 
PUT:存在更新,不存在创建
 
资源创建-》201,资源更新-》200 | 204
 
接收方不能忽略任何无法解析的Content-*头信息,并且需要回复501(not implemented)
 
对比与POST,PUT请求的资源非常明确,如果需要处理额外的资源,需要服务器返回重定向
 
DELETE:
 
删除资源,明确资源删除回复200,204 if no response entity,请求接收,为执行完,返回202(Accepted)
 
TRACE:
 
测试,诊断路径host,收到方需要将请求信息当作消息体(Content-type:message/http)返回200
 
TRACE请求不能包含消息体
 
不能缓存
 
CONNECT:
 
代理建立通道使用
 
referer:告知从哪个地址链接过来的
 
Http:半双工,单向流动,
 

其它:

轮训:间隔的发送请求,获取信息;处理低信息率情景,会浪费太多连接。
 
长轮训:客户端保持请求连接特定时间,直到请求的信息可用,或者到达超时时间,然后再重新发起连接。缺乏标准实现。
 
流化技术:客户端发送一个请求,服务端发送并维护一个持续更新和保持打开(设定时间)的响应。pingpong;防火墙和代理影响。
 
TCP:全双工。
 
websocket:自然的全双工,双向,单套接字连接。单一请求。
 
 
 
 

Http protocal的更多相关文章

  1. [转]Objective-c中@interface、@implementation、@protocal

    原处:http://blog.csdn.net/l271640625/article/details/8393531 以下Objective-c简称OC 从事java开发的程序员们都知道,在java中 ...

  2. 从C#到Objective-C,循序渐进学习苹果开发(3)--分类(category)和协议Protocal的理解

    本随笔系列主要介绍从一个Windows平台从事C#开发到Mac平台苹果开发的一系列感想和体验历程,本系列文章是在起步阶段逐步积累的,希望带给大家更好,更真实的转换历程体验.本文继续上一篇随笔<从 ...

  3. IOS Delegate & protocal

    总结一下: delegate是一个方式,程序组成单元之间分工的一种协调思想 protocal 这个东西不能单独说,要与它相关的两个主要东西一起说,一个是 委托者 通常是VIEW, 一个是被委托者 通常 ...

  4. Google Protocal Buffer

    Google Protocal Buffer 是一种轻便高效的结构化数据存储格式,可以用于结构化数据串行化或者说序列化.它很适合做数据存储或RPC数据交换格式. 串行化(序列化):将对象存储到解释中式 ...

  5. websocket protocal

    same-orgins:浏览器同源策略的安全模型   持久化协议   双向双工  多路复用, 同时发信息   区别HTTP连接特点:  http只能由客户端发起,一个request对应一个respon ...

  6. IRC(Internet Relay Chat Protocol) Protocal Learning && IRC Bot

    catalogue . Abstract . INTRODUCTION . 通信协议Connection Registration Action . 通信协议Channel operations Ac ...

  7. Objective-c中@interface、@implementation、@protocal

    以下 void print(); }; class AC{ }; 这时候,AI和AC是独立存在,AC不会因为没有和AI建立关系而编译错误,将AC做以下修改后,AI才和AC建立了关系,AC必须实现AI中 ...

  8. SMB(Server Message Block) Protocal Research

    catalogue . 什么是SMB . 基础SMB协议 . SMB Clients and Servers 1. 什么是SMB 全世界有很多的客户端和服务端软件实现了SMB协议,全部windows工 ...

  9. facebook api & oauth protocal

    http://tools.ietf.org/html/draft-ietf-oauth-v2-31#section-10.5 http://stackoverflow.com/questions/14 ...

随机推荐

  1. 【转】 Android xml中 @和?区别,style和attr小结

    引用资源时,使用@还是?的区别,例如在设置style的时候既可以使用@也可以使用? style="?android:attr/progressBarStyleHorizontal" ...

  2. jQuery页面滚动数字增长插件

    <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...

  3. [转] Eclipse安装SVN插件

    eclipse里安装SVN插件,一般来说,有三种方式: 1. 直接下载SVN插件,将其解压到eclipse的对应目录里 2. 使用eclipse 里Help菜单的“Install New Softwa ...

  4. 中国城市json

    [{ "label": "北京Beijing010", "name": "北京", "pinyin" ...

  5. atom / vscode (配置c++环境流程)

    最初主要是被这个炫酷的插件吸引了,这么打代码太特么有激情了 还有跳舞的初音姐姐哦!! 现附上一篇文章,这篇文章步骤讲得很详细了 http://blog.csdn.net/qq_36731677/art ...

  6. 【gulp】Gulp的安装和配置 及 系列插件

    注意:要安装俩次gulp(全局和本地):全局安装gulp是为了执行gulp任务,本地安装gulp则是为了调用gulp插件的功能. 之前由大牛帮忙配置的gulp来用.今天时间充裕,就和小伙伴一起动手配置 ...

  7. MyBatis的缓存分析

    一:MyBatis缓存简介 MyBatis支持声明式数据缓存(declarative data caching).当一条SQL语句被标记为“可缓存”后,首次执行它时从数据库获取的所有数据会被存储在一段 ...

  8. Robosup3D平台搭建

    目录 1.安装simspark及默认播放器 安装依赖库/下载simspark源码 编译并安装simspark 编译并安装rcssmonitor3d播放器 2.安装Roboviz播放器 安装java 安 ...

  9. golang 实现海明距离 demo

    Simhash的算法简单的来说就是,从海量文本中快速搜索和已知simhash相差小于k位的simhash集合,这里每个文本都可以用一个simhash值来代表,一个simhash有64bit,相似的文本 ...

  10. 浅析 golang interface 实现原理

    interface 在 golang 中是一个非常重要的特性.它相对于其它语言有很多优势: duck typing.大多数的静态语言需要显示的声明类型的继承关系.而 golang 通过 interfa ...