1. HTTP 协议的主要特点:
- 简单快速 「url」
- 灵活
- 无连接 只连接一次后断开
- 无状态 服务端无法记住客户端的身份
2. HTTP 报文额组成部分:
请求报文
- 请求行 「HTTP方法、页面地址、HTTP协议以及版本」
- 请求头 「key、value」要的内容
- 空行「key、value」标志,请求头结束,改为请求体了
- 请求体
响应报文
- 状态行
- 响应头
- 空行
- 响应体
3. HTTP 方法:
- GET 获取资源
- POST 传输资源
- PUT 更新资源
- DELETE 删除资源
- HEAD 获得报文首部
GET 与 POST 的区别
- GET 在浏览器回退时是无害的,而 POST 会再次提交请求
- GET 产生的 URL 地址可以被收藏,而 POST 不可以
- GET 请求会被浏览器主动缓存,而 POST 不会,除非你手动设置
- GET 只能进行 url 编码,而 POST 支持多种编码
- GET 请求参数会被完整保留在浏览器历史记录中,而 POST 中的参数不会被保留「为了防止 CSRF 攻击,将 POST 改为 GET」
- GET 请求在 URL 中传送的参数是有长度限制的,而 POST 没有限制
- 对参数的数据类型,GET 只接受 ASCII 字符,而 POST 没有
- GET 比 POST更不安全,因为参数直接暴露在URL上,所以不能用来传递敏感信息
- GET 参数通过 URL 传递,POST 放在 Request body 中
3. HTTP 状态码:
- 1xx:指示信息 - 表示请求已接收,继续处理
- 2xx:成功 - 表示请求已被成功接收
- 3xx:重定向 - 要完成请求必须进行更进一步的操作
- 4xx:客户端错误 - 请求有语法错误或请求无法实现
- 5xx:服务器错误 - 服务器未能实现合法的请求
具体:
- 200 OK:客户端请求成功
- 206 Partial Content:客户发送了一个带有 Range 头的 GET 请求,服务器完成了它 「video、audio 播放视频、音频地址,文件过大」
- 301 Moved Permanently:所请求的页面已转移到新的 url
- 302 Found:所请求的页面已经临时转移至新的 url
- 304 Not Modidied:客户端有缓冲的文档并发出了一个条件性的请求,服务器告诉客户,原来缓冲的文档还可以继续使用
- 400 Bad Request:客户端请求语法错误,不能被服务器理解
- 401 Unauthorized:请求未经授权,这个状态代码必须和 WWW-Authenticate 报头域一起使用
- 403 Forbidden:对被请求页面的访问被禁止
- 404 Not Found:请求资源不存在
- 500 Internal Server Error:服务器发生不可预期的错误原来缓冲的文档还可以继续使用
- 503 Server Unavailable:请求未完成,服务器临时过载或当机,一段时间后可能恢复正常
4. HTTP 持久连接:
- HTTP 协议采用「请求-应答」模式,当使用普通模式,即非 Keep-Alive 模式时,每个请求/应答客户和服务器都要新建一个连接,完成之后立即断开连接「HTTP 协议为无连接的协议」
- 当使用 Keep-Alive 模式「又称持久连接、连接重用」时,Keep-Alive 功能使客户端到服务器端的连接持续有效,当出现对服务器的后继请求时,Keep-Alive 功能避免了建立或者重新建立连接「HTTP 1.1 版本才支持」
5. HTTP 管线化:
- 在使用持久连接的情况下,某个连接上消息的传递类似于 请求1-》响应1-》请求2-》响应2-》请求3-》响应3
- 某个连接上的消息变成了类似这样 请求1-》请求2-》请求3-》响应1-》响应2-》响应3
特点:
- 管线化机制通过持久连接完成,仅 HTTP/1.1 支持此技术
- 只有 GET 和 HEAD 请求进行管线化,而 POST 则有所限制
- 初次创建连接时不应启动管线机制,因为对方服务器不一定支持 HTTP/1.1 版本的协议
- 并不会带来性能的大幅度提升
License
- 可以拷贝、转发,但是必须提供原作者信息,同时也不能将本项目用于商业用途。
**粗体** _斜体_ [链接](http://example.com) `代码` - 列表 > 引用
。你还可以使用@
来通知其他用户。