- 浏览器负责发起请求;
- 服务器在 80 端口接收请求;
- 服务器负责返回内容(响应);
- 浏览器负责下载响应内容;
HTTP 的做用就是指导浏览器和服务器如何进行沟通。html
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 . 要上传的数据chrome
- 请求最多包含四部分,最少包含三部分。(也就是说第四部分能够为空);
- 第三部分永远都是一个回车(\n);
- 动词有 GET POST PUT PATCH DELETE HEAD OPTIONS 等;
- 这里的路径包括「查询参数」,但不包括「锚点」;
- 若是你没有写路径,那么路径默认为 /;
- 第 2 部分中的 Content-Type 标注了第 4 部分的格式。
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 规范。
curl -s -v -H "clay:233" -- "https://www.baidu.com"
复制代码
curl -X POST -d "1234567890" -s -v -H "Frank: xxx" -- "https://www.baidu.com"
复制代码
则请求内容为: bash
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
复制代码