http协议是HTTP协议(HyperText Transfer Protocol,超文本传输协议)是因特网上应用最为普遍的一种网络传输协议,全部的WWW文件都必须遵照这个标准。html
HTTP是一个基于TCP/IP通讯协议来传递数据(HTML 文件, 图片文件, 查询结果等),它被设计用于Web浏览器和Web服务器之间的通讯,但它也能够用于其余目的。chrome
下面经过一些简单的实例更加充分的加深理解和记忆shell
cURL是一个利用URL语法在命令行下工做的文件传输工具,1997年首次发行。它支持文件上传和下载,因此是综合传输工具,但按传统,习惯称cURL为下载工具。cURL还包含了用于程序开发的libcurl。浏览器
cURL支持的通讯协议有FTP、FTPS、HTTP、HTTPS、TFTP、SFTP、Gopher、SCP、Telnet、DICT、FILE、LDAP、LDAPS、IMAP、POP三、SMTP和RTSP。其中有许多都是较为经常使用的。bash
curl https://www.baidu.com/
服务器
这是curl最简单的使用方法,运行上面的命令能够获取 www.baidu.com/ 指向的页面,一样,若是这里的 URL 指向的是一个文件或者一幅图,均可以直接下载到本地。网络
curl -s -v -H "ceshi: xxx" -- "https://www.baidu.com"
//其中 ceshi xxx 可写可不写app
curl -X POST -s -v -H "Frank: xxx" -- "https://www.baidu.com"
dom
二者除了动词不同以外,其余没差异curl
curl -X PSOT -d '123456789' -s -v -H "ceshi: xxx" -- "https://www.baidu.com"
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 要上传的数据
1.请求最多包含四部分,最少包含三部分。(也就是说第四部分能够为空)
2.第三部分永远都是一个回车(\n)
3.动词有 GET POST PUT PATCH DELETE HEAD OPTIONS 等
4.这里的路径包括「查询参数」,但不包括「锚点」
5.若是你没有写路径,那么路径默认为 /
6.第 2 部分中的 Content-Type 标注了第 4 部分的格式
若是有请求的第四部分,那么在 FormData 或 Payload 里面能够看到
以百度网站为例:
请求了以后,应该都能获得一个响应,除非断网了,或者服务器宕机了。
以上面百度网站为例,请求以后获得的响应:
HTTP/1.1 200 OK
Bdpagetype: 1
Bdqid: 0xcde9887a0001eff5
Cache-Control: private
Connection: Keep-Alive
Content-Encoding: gzip
Content-Type: text/html
Cxy_all: 97150107_hao_pg+9b4dbc031eaceebc7ac0b0a5b7293715
Date: Fri, 15 Feb 2019 02:42:30 GMT
Expires: Fri, 15 Feb 2019 02:42:22 GMT
P3p: CP=" OTI DSP COR IVA OUR IND COM "
Server: BWS/1.1
Set-Cookie: BDRCVFR[4Fo_HGJeHPY]=mk3SLVN4HKm; path=/; domain=.baidu.com
Set-Cookie: delPer=0; path=/; domain=.baidu.com
Set-Cookie: BDSVRTM=0; path=/
Set-Cookie: BD_HOME=0; path=/
Set-Cookie: H_PS_PSSID=; path=/; domain=.baidu.com
Strict-Transport-Security: max-age=172800
Vary: Accept-Encoding
X-Ua-Compatible: IE=Edge,chrome=1
Transfer-Encoding: chunked
复制代码
1 协议/版本号 状态码 状态解释
2 Key1: value1
2 Key2: value2
2 Content-Length: 17931
2 Content-Type: text/html
3
4 要下载的内容
经常使用状态码:
响应码 | 解释 |
---|---|
200 | 表示成功,能够正常响应 |
301 | 表示永久重定向,之后不要在访问这个地址啦 |
302 | 表示暂时重定向,暂时不要访问这个地址啦,隔段时间就能够访问 |
403 | 表示你错了,服务器已经理解请求,可是拒绝执行它 |
404 | 表示你错了,没有找到文件或目录,但容许用户的后续请求 |
500 | 表示服务器内部遇到错误,没法处理请求 |
503 | 表示服务器暂时出现了问题,隔段时间能够恢复 |
1.打开 Network
2.输入网址
3.选中第一个响应
4.查看 Response Headers,点击「view source」//注意必定要点击!!!
5.你会看到响应的前两部分
6.查看 Response 或者 Preview,你会看到响应的第 4 部分
以上基本上就是http经常使用知识啦,内容比较多,须要屡次回顾才能加深理解和记忆。