1.浏览器与服务器的交互图 by饥人谷
- 浏览器负责发起请求;
- 服务器在 80 端口接收请求;
- 服务器负责返回内容(响应);
- 浏览器负责下载响应内容;
HTTP 的作用就是指导浏览器和服务器如何进行沟通。
2.HTTP的请求
2.1.请求的格式
1 . 动词 路径 协议/版本
2 . key1: value1
2 . key2: value2
2 . key3: value3
2 . Content-Type: application/x-www-form-urlencoded
2 . Host: www.baidu.com
2 . User-Agent: curl/7.54.0
3 . (回车)
4 . 要上传的数据
- 请求最多包含四部分,最少包含三部分。(也就是说第四部分可以为空);
- 第三部分永远都是一个回车(\n);
- 动词有 GET POST PUT PATCH DELETE HEAD OPTIONS 等;
- 这里的路径包括「查询参数」,但不包括「锚点」;
- 如果你没有写路径,那么路径默认为 /;
- 第 2 部分中的 Content-Type 标注了第 4 部分的格式。
2.2 使用chrome查看请求
- 打开network
鼠标右击,点击检查,选择network; - 地址栏输入网址后回车,如www.baidu.com;
- 选择最上面的www.baidu.com,选择request,点击view source; 4.可见请求前三部分;
- 如果有请求的第四部分,那么在 FormData 或 Payload 里面可以看到。
3.HTTP的响应
3.1 响应的格式
1 . 协议/版本号 状态码 状态解释
2 . Key1: value1
2 . Key2: value2
2 . Content-Length: 17931
2 . Content-Type: text/html
3 .
4 . 要下载的内容
- 状态码是服务器对浏览器说的话,
1xx 不常用 ;
2xx 表示成功 ;
3xx 表示滚吧 ;
4xx 表示你丫错了 ;
5xx 表示好吧,我错了;- 状态解释没什么用;
- 第 2 部分中的 Content-Type 标注了第 4 部分的格式;
- 第 2 部分中的 Content-Type 遵循 MIME 规范。
3.2 使用chrome查看响应
- 鼠标右击,点击检查,选择network;
- 地址栏输入网址后回车,如www.baidu.com;
- 选择第一个响应,选择response,点击view source;
- 我们会看到响应的前两部分;
- 查看 Response 或者 Preview,会看到响应的第 4 部分。
4. Curl命令的使用
- 在bush里输入
curl -s -v -H "clay:233" -- "https://www.baidu.com"
复制代码
- 引号里内容无意义,输入什么返回什么;
- 可查看到请求;
- 可看到响应;
- 更改命令,加上-X POST,-d "1234567890", 输入命令如:
curl -X POST -d "1234567890" -s -v -H "Frank: xxx" -- "https://www.baidu.com"
复制代码
则请求内容为:
POST / HTTP/1.1
Host: www.baidu.com
User-Agent: curl/7.54.0
Accept: */*
Frank: xxx
Content-Length: 10
Content-Type: application/x-www-form-urlencoded
1234567890
复制代码
- -s 表示不要显示进度条;
- -v 显示请求与响应;
- -H “Apple: xxx” 添加一个响应头;
- -- “www.baidu.com” 请求的网址;
- Get 为获取内容,Post为上传内容;
- Host: www.baidu.com把要访问的域名告诉它,搭建多服务器时用到;
- User-Agent表示用什么软件发起;
- Accept: */*表示接受所有返回的内容。