HTTP协议的主要特点
简单快速,灵活,无连接,无状态
HTTP报文组成部分
请求报文
1.请求行
HTTP方法,地址,页面协议,版本
2.请求头
key value 值,告诉服务器需要啥
3.空行
隔开请求头跟请求体
4.请求体
数据
响应报文
状态行,响应头,空行,响应体
HTTP方法
GET 获取资源
POST 传输资源
PUT 更新资源
DELETE 删除资源
HEAD 获得报文首部
POST跟GET的区别
GET在浏览器回退时是无害的,而POST会再次提交请求。 重点记住
GET产生的URL地址可以被Bookmark,而POST不可以。
GET请求会被浏览器主动cache,而POST不会,除非手动设置。 重点记住
GET请求只能进行url编码,而POST支持多种编码方式。
GET请求参数会被完整保留在浏览器历史记录里,而POST中的参数不会被保留。重点记住
GET请求在URL中传送的参数是有长度限制的,而POST没有。重点记住
对参数的数据类型,GET只接受ASCII字符,而POST没有限制。
GET比POST更不安全,因为参数直接暴露在URL上,所以不能用来传递敏感信息。
GET参数通过URL传递,POST放在Request body中 重点记住
HTTP状态码
1xx: 指示信息 - 表示请求已接收,继续处理
2xx: 成功 - 表示请求已经被成功接收
3xx: 重定向 - 要完成请求必须进行更进一步的操作
4xx: 客户端错误 - 请求语法错误或者请求无法实现
5xx: 服务器错误 - 服务器未能实现合法的请求
200: 客户端请求成功
206 Partial Content: 客户发送了一个带有Range头的Get请求,服务器完成了他
301 Moved Permanently: 所请求的页面已经转移至新的URL
302 Found : 所请求的页面已经临时转移至新的URL
304 NOT Modified:客户端有缓存的文档并发出了一个条件性的请求,服务端告诉客户,原来的缓冲的文档还可以继续使用
400 Bad Request: 客户端请求有语法错误,不能被服务器所理解
401 Unauthorized:请求未经授权,这个状态代码必须和WWW-Authenticate报头一起使用
403 Forbidden: 对被请求页面的访问被禁止
404 Not fonud:请求资源不存在
500 InterNal Server Error:服务器发生了不可预期的错误
503 Server Unavailable : 请求未完成,服务器临时过载或当机,一段时间后可能恢复正常
HTTP持久链接
当使用Keep-alive模式时,keep-alive功能使客户端到服务端的链接持续有效,当出现对服务器的后续请求时,keep-alive功能避免了建立或者重新建立链接 (版本1.1才支持这个功能)
HTTP管线化
持久链接的情况下,某个链接上的消息的传递类似于
请求1 -> 响应1 -> 请求2 -> 响应2 -> 请求3 -> 响应3
当管线化的时候,请求将会打包发送,然后响应也会打包发回来,而不是一次请求一次响应这么循环
变成 请求1 -> 请求2 -> 请求3 -> 响应1 -> 响应2 -> 响应3这种形式
管线化机制须通过永久连接(persistent connection)完成,并且只有 GET 和 HEAD 等要求可以进行管线化,非幂等的方法,例如POST会有许多限制。连续的 GET 和 HEAD 请求总可以管线化的。一个连续的幂等请求,如 GET,HEAD,PUT,DELETE,是否可以被管线化取决于一连串请求是否依赖于其他的。此外,初次创建连接时也不应引导管线机制,因为对方(服务器)不一定支持 HTTP/1.1 版本的协议。
HTTP 管线化同时依赖于客户端和服务器的支持。遵守 HTTP/1.1 的服务器支持管线化。这并不是意味着服务器需要提供管线化的回复,而只是要求在收到管线化的请求时候不会失败。