HTTP协议 (Hyper Text Transfer Protocol)
HTTP是一个基于TCP/IP通信协议来传递数据,包括html文件、图像、结果等,即是一个客户端和服务器端请求和应答的标准。
HTTP协议特点
- http无连接:限制每次连接只处理一个请求,服务端完成客户端的请求后,即断开连接。(传输速度快,减少不必要的连接,但也意味着每一次访问都要建立一次连接,效率降低)
- http无状态:对于事务处理没有记忆能力。每一次请求都是独立的,不记录客户端任何行为。(优点解放服务器,但可能每次请求会传输大量重复的内容信息)
- 客户端/服务端模型:客户端支持web浏览器或其他任何客户端,服务器通常是nginx或者apache等
- 简单快速
- 灵活:可以传输任何类型的数据
一次HTTP请求过程
域名 =》DNS域名解析 =》TCP三次握手建立连接 =》传输http报文 =》四次挥手断开连接
TCP三次握手过程
- 第一次握手客户端需要发送一个syn=1告诉服务端需要联机,并且会同时发送一个随机生成的顺序号码(seq)。
- 第二次握手由服务端发起,服务端需要回复客户端一个确认ACK,这个值为第一次客户端生成的顺序号码加1,另外也生成一个随机顺序号码给到客户端。
- 第三次握手由客户端收到第二次握手的消息后,回复服务端一个确认消息ACK,这个值为服务端的顺序号码加1,也会发送一个seq。
第一次握手,是客户端需要确认自己发消息没问题,服务端收到消息以后证明自己收消息没问题,这时他还需要证明自己发消息没问题所以他发起第二次握手。
客户端收到第二次握手的消息后确认了自己的发消息和收消息都没问题,但这时候服务端只知道自己收消息没有问题,他第二次发出的消息他并不知道客户端是否成功接收了。
所以有了第三次握手,告诉服务端我收到了,你发消息没问题。这时,就证明了客户端和服务端双方的收发都没有问题。
HTTP请求报文
一个HTTP请求报文由请求行(request line)、请求头部(header)和请求体(body)组成。
- 请求行:请求方法、请求地址和协议版本
- 请求头:主要说Content-Type(请求的与实体对应的MIME信息)
- 常见取值 :
application/x-www-form-urlencoded (使用jquery发送ajax请求会默认类型)
application/json
multipart/form-data (传输文件固定类型) - 后端如何接收:(PHP)
取值为application/x-www-data-urlencoded情况下$_POST 和 php://input均有值。
取值为 application/json 时$_POST无值。
取值为multipart/form-data 时php://input无值。此时应该用$_POST来获取字段,$_FILES 来获取上传的文件信息
- 常见取值 :
- 请求体:
- 常见类型 :
application/x-www-form-urlencoded :a=1&b=2
application/json :"{"a":1,"b":2}"
- 常见类型 :
HTTP响应报文
HTTP响应报文主要由状态行、响应头、及响应数据组成。
- 状态行:协议版本,状态码,状态码描述。
- 响应头:主要说Content-Type
- 常见值 :
text/html : HTML格式
text/plain :纯文本格式
text/xml : XML格式
image/gif :gif图片格式
image/jpeg :jpg图片格式
image/png:png图片格式
- 常见值 :
四次挥手断开
通过前面,我们已经知道ACK是用来应答的,SYN是用来代表连接的。而这里的FIN报文就是代表断开连接的,当主动方没有数据再需要传输给对方时,会向对方发起FIN报文,但这时候被动方不会立马断开连接,他只会回复一个ACK告诉主动方你发的FIN报文我收到了,很可能不会立马关闭,因为他可能还没处理完请求,可能还有消息需要发送,这时主动方进入FIN_WAIT_2状态。等被动发也没有消息需要发送了,这时候才会也发一个FIN给主动方,主动方回复以后,连接断开。
COOKIE
Http 协议中引入了 cookie 技术,用来解决 http 协议无状态的问题。通过在请求和响应报文中写入 Cookie 信息来控制客户端的状态;Cookie会根据从服务器端发送的响应报文内的一个叫做 Set-Cookie 的首部字段信息,通知客户端保存 Cookie。当下次客户端再往该服务器发送请求时,客户端会自动在请求报文中加入 Cookie 值后发送出去。后端以 session 这样的机制来保存服务端的对象状态。