1.HTTP协议的主要特点
1.简单快速
每个资源有固定URI
2.灵活
在http头中修改数据类型就可以传输不同的数据类型,很灵活
3.无连接
每次连接完之后,连接状态都会断开,不会保持连接状态
4.无状态
在服务器端不会记录请求状态
2.HTTP报文的组成部分
1.请求报文
1.请求行
http方法
页面地址
http协议及版本
2.请求头
格式key/valve
用来告诉服务器你需要什么内容
3.空行
用于间隔请求头和请求体
4.请求体
2.响应报文
1.状态行
http协议及版本
http状态码
2.响应头
格式 key/value
3.空行
用于间隔请求头和请求体
4.响应体
3.HTTP方法
GET——————————> 获取资源
POST—————————> 传输资源
PUT——————————> 更新资源
DELETE————————> 删除资源
HEAD—————————> 获取报文首部
4.POST和GET的区别
5.HTTP状态码
1xx:指示信息
2xx:成功
200 OK:客户端请求成功
206 Partial Content :客户发送了一个带有Range头的GET请求,服务器完成了它
3xx:重定向
301 Moved Permanently:所请求的页面已转移至新的url
302 Found:所请求的页面已经临时转移至新的url
304 Not Modified :客户端有缓存的文档并发出了一个条件性的请求,服务器告诉客户原来缓冲的文档还可以继续使用
4xx:客户端错误
400 Bad Request:客户端请求有语法错误,不能被服务器所理解
401 Unauthorized:请求未经授权,这个状态码必须和WWW-Authenticate报头域一起使用
403 Forbidden:对被请求的页面访问静止
404 Not Found:请求资源不存在
5xx:服务器错误
500 Internal Server Error:服务器发生不可预期的错误原来缓冲的文档还可以继续使用
503 Server Unavailable:请求未完成,服务器临时过载或当机,一段时间后可能恢复正常
6.什么是持久连接
需要http 1.1及以上
HTTP 协议采用“请求-应答”模式,当使用普通模式,即非 Keep-Alive 模式时,每个请求/应答客户和服务器都要新建一个连接,完成之后立即断开裂解(HTTP完成之后即可断开连接的协议)
当使用 Keep-Alive 模式 (又称持久连接,连接重用)时,Keep-Alive功能使客户端到服务器端端连接持续有效,当出现对服务器端后续请求时,Keep-Alive功能避免了建立或者重新建立连接
7.什么是管线化
-
在使用持久连接的情况下,某个连接上消息的传递类似于
请求1—>响应1—>请求2—>响应2—>请求3—>响应3
-
某个连接上的消息变成了这样(即管线化(在持久连接的状态下完成))
请求1—>请求2—>请求3—>响应1—>响应2—>响应3
——————————————————————————————————————————————————————————————
- 管线化机制通过持久连接完成,近HTTP/1.1支持此技术
- 只有GET和HEAD请求可以管线化,而POST则有所限制
- 初次创建连接时不应启动管线机制,因为对方(服务器)不一定支持HTTP/1.1版本的协议
- 管线化不会影响响应到来的顺序,如上面的例子所示,响应返回的顺序也并未改变
- HTTP/1.1要求服务器端支持管线化,带并不要求服务器端也对响应进行管线化处理,只是要求对于管线化的请求不失败即可
- 由于上面提到的服务器问题,开启管线化很可能并不会带来大幅度的性能提升,而且很多服务器端和处理程序对管线化的支持并不好,因此现代浏览器如Chrome和Firefox默认并未开启管线化支持
**粗体** _斜体_ [链接](http://example.com) `代码` - 列表 > 引用
。你还可以使用@
来通知其他用户。