文章目录
1. HTTP 协议
1.1 什么是 HTTP 协议
HTTP 协议(HTTP 全称为 Hyper Text Transfer Protocol,超文本传输协议)是一个简单的请求-响应协议,也是一种应用非常广泛的应用层协议。
PS: 所谓超文本指的是传输的内容不仅是文本,还可以是其他资源比如图片,音频,视频等数据。
HTTP 协议是目前最主流使用的一种应用层协议,平时打开的网站就是通过 HTTP 协议来传输数据的。当我们输入一个网址(URL)时,浏览器就会给服务器发送一个 HTTP 请求,然后服务器就会返回一个 HTTP 响应,这个响应结果被解析后就会是我们平时看到的页面。
1.2 HTTP 协议格式
HTTP 是一个超文本格式的协议,可以通过浏览器的开发者工具或者 Fiddler 抓包,分析 HTTP 请求/响应的内容。
使用开发者工具抓包:
按 F12 键打开开发者工具,也可以通过工具栏的更多工具找开发者工具。
使用 Fiddler 抓包分析,HTTP 协议交互过程中包含 Request 请求和 Response 响应两个部分。
Request 请求头:请求行(Method 、URL 、Version)、请求报头、空行、请求正文
Response 响应头:状态行(Version、状态码、状态码描述)、响应报头、空行、响应正文
2. Fiddler 的用法
2.1 Request 请求
2.1.1 请求行:Method 、URL 、Version
- Method 方法类型:
GET 获取资源
POST 传输实体主体
PUT 传输文件
HEAD 获得报文首部
DELETE 删除文件
OPTIONS 访问支持的方法
TRACE 追踪路径
CONNECT 要求用隧道协议连接代理
LIKE 建立和资源之间的联系
UNLIKE 断开连接关系
- URL 请求地址
URL (Uniform Resource Locator 同意资源定位符),也就是俗称的网址。
URL 构成:http://user:pass@www.example.jp:80/dir/index.html?uid=1#ch1
http :协议方案名,常见的有 http 和 https;
user:pass : 登录信息,现在一般不会用,可省略;
www.example.jp :服务器地址;
80:端口号,http 协议默认使用 80 端口,https 默认使用 443 端口,可省略,浏览器会根据协议类型自动决定使用哪个端口;
/dir/index.html :带层次的文件路径;
uid=1:查询字符串,本质是一个键值对结果,键值对之间使用&分隔,键和值之间使用 = 分隔;
ch1:片段标识符,主要用于页面内跳转。
- Version 版本号
通常是 HTTP 协议 的 1.0、1.1 版本
2.1.2 请求报头
格式:
key : value
key : value …
请求报头中常见的种类:
- Host:表示服务器主机的地址和端口
- Content - Length:表示 boby 中的数据长度
- Content - Type(重点):表示请求 boby 中的数据格式
常见的有 application/x-www-form-urlencoded:form 表单提交的数据格式;multipart/form-data:form 表单提交的数据格式;application/json:数据为 json 格式。 - User - Agent:表示操作系统的属性
- Referer:表示这个页面是从哪个页面跳转来的
- Cookie:有“身份标识”的功能
2.1.3 空行
作用:分隔请求报头和正文。
2.1.4 请求正文
用来存储开发者传递的参数和参数的值,正文中的内容格式和 Content - Type 相关,有application/x-www-form-urlencoded,multipart/form-data,application/json。
上图中的user_login = xxx 就是正文中传递的参数和参数的值。
2.2 Response 响应
2.2.1 状态行:Version、状态码、状态码描述
- 状态码
200 访问成功
301 永久重定向
302 临时重定向
403 没有权限访问
404 访问页面不存在
500 服务器错误,代码有问题
502 网关错误
504 访问超时
2.2.2 响应报头
响应报头的基本格式和请求报头格式基本一致:
key : value
key : value …
2.2.3 空行
作用:分隔响应报头和正文。