服务器与浏览器的交互
- 浏览器负责发起请求
- 服务器在 80 端口接收请求
- 服务器负责返回内容(响应)
- 浏览器负责下载响应内容
HTTP 的作用就是指导浏览器和服务器如何进行沟通。
请求
请求的格式
1 动词 路径 协议/版本
2 Key1: value1
2 Key2: value2
2 Key3: value3
...
2 Content-Type: application/x-www-form-urlencoded
2 Host: www.xxx.com
2 User-Agent: curl/7.54.0
3
4 要上传的数据
- 请求包括四部分,但第四部分内容可以为空
- 动词有 GET POST PUT PATCH DELETE HEAD OPTIONS 等
- 路径包括这里的路径包括查询参数,但不包括锚点; 如果没有写路径, 则路径默认为/
- 第 2 部分中的 Content-Type 标注了第 4 部分的格式
- 第三部分永远都是一个回车(
\n
)
响应
发起一个请求之后,一般都会得到一个响应,除非是断网或者服务器宕机了
响应的格式
1 协议/版本号 状态码 状态解释
2 Key1: value1
2 Key2: value2
2 Content-Length: 17931
2 Content-Type: text/html
3
4 要下载的内容
- HTTP状态码(HTTP Status Code)是用以表示网页服务器超文本传输协议响应状态的3位数字代码https://zh.wikipedia.org/wiki/HTTP%E7%8A%B6%E6%80%81%E7%A0%81
- 第 2 部分中的 Content-Type 标注了第 4 部分的格式,遵循 MIME 规范
- 响应的第四部分可以很长
如何用Chrome开发者工具查看 HTTP 请求和响应内容
- 打开network
- 地址栏输入网址
- 在 Network 点击,查看 request Headers,点击view source 然后就可以看到请求的前三部分
- 如果请求有第四部分,可以在FormData里面可以看到
-
输入网址后,选中第一个响应,查看 Response Headers,点击view source,就会看到响应的前两部分。查看 Response,可以看到响应的第 4 部分
curl命令
curl是一种命令行工具,作用是发出网络请求,然后得到和提取数据,显示在"标准输出"(stdout)上面。
curl命令可以查看网页源代码,直接在curl命令后加网址,如curl www.example.com
;也可以用来显示通讯进程,如curl -v www.example.com
。使用curl命令进行请求时,有GET(获取内容)和POST(上传内容)两种方法
示例:
-
curl -s -v -H "xxx: yyy" -- "https://www.example.com"
-s
表示静默模式。不输出任何东西
-v
表示显示请求和响应(不加-v
为只显示响应)
-H
表示增加一个头信息 -
curl -X POST -d "1234567890" -s -v -H "xxx: yyy" -- "https://www.example.com"
-d
后为请求上传内容
curl默认的HTTP动词是GET,使用-X
参数可以支持其他动词。
网友评论