一. 概念
1. Hyper Text Transfer Protocol 超文本传输协议
- 传输协议:定义了,客户端和服务器端通信时,发送数据的格式
- 特点:
1. 基于TCP/IP的高级协议(tcp 三次握手 安全的)
2. 默认端口号:80
3. 基于请求/响应模型的:一次请求对应一次响应
4. 无状态的:每次请求之间相互独立,不能交互数据
2. 历史版本:
- 1.0:每一次请求响应都会建立新的连接
- 1.1:复用连接
二. 请求消息数据格式
1. 请求行
- 格式请求方式 请求url 请求协议/版本
- 请求方式:
- HTTP协议有7中请求方式,常用的有2种
- GET:
1. 请求参数在请求行中,在url后(网址中)。
2. 请求的url长度有限制的
3. 不太安全 - POST:
1. 请求参数在请求体中
2. 请求的url长度没有限制的
3. 相对安全
- GET:
2. 请求头:客户端浏览器告诉服务器一些信息
(格式 : 请求头名称: 请求头值)
常见的请求头:
-
User-Agent:浏览器告诉服务器,我访问你使用的浏览器版本信息
* 可以在服务器端获取该头的信息,解决浏览器的兼容性问题 -
Referer:
- 告诉服务器,我(当前请求)从哪里来?
- 作用:
1. 防盗链:
2. 统计工作:
(简单解释防盗链和统计:优酷服务器中有战狼的资源,优酷首页可以请求到服务器的资源,如果某网站也去请求优酷服务器视图得到战狼的资源就是盗链行为。我们可以在优酷的服务器中对referer做一个逻辑处理,只有从优酷首页来的才能获取,其他网站来的不可以获取。统计工作主要看流量是从哪些网站来的)
- 作用:
- 告诉服务器,我(当前请求)从哪里来?
-
Accept: 告诉服务器我可以接受的格式,语言环境,压缩格式。
-
Connection: keep-alive:表示 连接活着 表示可以复用。
3. 请求空行
空行,就是用于分割POST请求的请求头,和请求体的。
4. 请求体(正文):
封装POST请求消息的请求参数的(Get的请求没有请求体)
三.响应消息数据格式
响应消息:服务器端发送给客户端的数据
数据格式:
1. 响应行
- 组成:协议/版本 响应状态码 状态码描述
- 响应状态码:服务器告诉客户端浏览器本次请求和响应的一个状态。
- 状态码都是3位数字
- 分类:
- 1xx:服务器就收客户端消息,但没有接受完成,等待一段时间后,发送1xx多状态码
- 2xx:成功。代表:200
- 3xx:重定向。代表:302(重定向),304(访问缓存)
缓存机制: 浏览器会把网页上的静态资源存储到本地中,例如图片。下次再打开此网站这些数据就可以从本地缓存中拿取,可以减少浏览器和服务器交互。节约资源
- 4xx:客户端错误。
代表:
404(请求路径没有对应的资源)
405:请求方式没有对应的doXxx方法 - 5xx:服务器端错误。代表:500(服务器内部出现异常)
2. 响应头
- 格式:头名称: 值
- 常见的响应头:
- Content-Type:服务器告诉客户端本次响应体数据格式以及编码格式(上图中是utf-8)
- Content-disposition:服务器告诉客户端以什么格式打开响应体数据
- in-line:默认值,在当前页面内打开
- attachment;filename=xxx:以附件形式打开响应体。文件下载(比如点击一个链接不打开网页 直接下载东西)