HTTP入门

Posted whhjdi

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了HTTP入门相关的知识,希望对你有一定的参考价值。

HTTP www 互联网

---

##URI:统一资源标识符
URL:统一资源定位符
URN:统一资源名称

##HTTP:超文本传输协议
###HTTP请求:
curl -s -v -H "muxue: xxx" -- "https://www.baidu.com"
用 curl 创造一个请求,并得到响应
用 curl 创造一个请求,并得到响应
请求的内容为

> GET / HTTP/1.1
> Host: www.baidu.com
> User-Agent: curl/7.58.0
> Accept: */*
> muxue: xxx
>

curl -X POST -s -v -H "muxue: xxx" -- "https://www.baidu.com"
请求的内容为

> POST / HTTP/1.1
> Host: www.baidu.com
> User-Agent: curl/7.58.0
> Accept: */*
> muxue: xxx
>

curl -X POST -d "1234567890" -s -v -H "muxue: xxx" -- "https://www.baidu.com"
请求的内容为

> POST / HTTP/1.1
> Host: www.baidu.com
> User-Agent: curl/7.58.0
> Accept: */*
> muxue: xxx
> Content-Length: 10
> Content-Type: application/x-www-form-urlencoded
>

>1234567890
请求最多包含四部分,最少包含三部分。(也就是说第四部分可以为空)
第三部分永远都是一个回车(\n)
动词有 GET POST PUT PATCH DELETE HEAD OPTIONS 等
这里的路径包括「查询参数」,但不包括「锚点」
如果你没有写路径,那么路径默认为 /
第 2 部分中的 Content-Type 标注了第 4 部分的格式

###用 Chrome 发请求
打开 Network
地址栏输入网址
在 Network 点击,查看 request,点击「view source」
点击「view source」
点击「view source」
点击「view source」
终于点了?可以看到请求的前三部分了
如果有请求的第四部分,那么在 FormData 或 Payload 里面可以看到
响应
请求了之后,应该都能得到一个响应,除非断网了,或者服务器宕机了。

###响应示例
上面三个请求示例,前两个请求对应的响应分别为

< HTTP/1.1 200 OK
< Accept-Ranges: bytes
< Cache-Control: private, no-cache, no-store, proxy-revalidate, no-transform
< Connection: Keep-Alive
< Content-Length: 2443
< Content-Type: text/html
< Date: Sat, 31 Mar 2018 10:07:20 GMT
< Etag: "588603eb-98b"
< Last-Modified: Mon, 23 Jan 2017 13:23:55 GMT
< Pragma: no-cache
* Server bfe/1.0.8.18 is not blacklisted
< Server: bfe/1.0.8.18
< Set-Cookie: BDORZ=27315; max-age=86400; domain=.baidu.com; path=/
<

<!DOCTYPE html>.......

< HTTP/1.1 302 Found
< Connection: Keep-Alive
< Content-Length: 17931
< Content-Type: text/html
< Date: Sat, 31 Mar 2018 10:07:59 GMT
< Etag: "54d97487-460b"
* Server bfe/1.0.8.18 is not blacklisted
< Server: bfe/1.0.8.18
<

<<html>

<head>
<meta http-equiv="content-type" content="text/html;charset=utf-8">


响应的格式
协议/版本号 状态码 状态解释
Key1: value1
Key2: value2
Content-Length: 17931
Content-Type: text/html

 

状态码要背,是服务器对浏览器说的话
1xx 不常用
2xx 表示成功
3xx 表示滚吧
4xx 表示你丫错了
5xx 表示好吧,我错了
状态解释没什么用
第 2 部分中的 Content-Type 标注了第 4 部分的格式
第 2 部分中的 Content-Type 遵循 MIME 规范
用 Chrome 查看响应
打开 Network
输入网址
选中第一个响应
查看 Response Headers,点击「view source」,点击「view source」,点击「view source」
你会看到响应的前两部分
查看 Response 或者 Preview,你会看到响应的第 4 部分

curl是基于URL语法在命令行方式下工作的文件传输工具,支持FTP,FTPS,HTTP,HTTPS,GOPHER,TELNET,DICT,FILE及LDAP等协议。

curl支持HTTPS认证,并且支持HTTP的POST,PUT等方法,FTP上传,HTTP上传,代理服务器,cookies,用户名/密码认证,通过http代理服务器上传文件到FTP服务器等等

太强大了,消化不了,暂时就这样吧

 

以上是关于HTTP入门的主要内容,如果未能解决你的问题,请参考以下文章

Cg入门20:Fragment shader - 片段级模型动态变色(实现汽车动态换漆)

Cg入门19:Fragment shader - 片段级模型动态变色

HTTP客户端代码片段

Cg入门16:Fragment shader - 片段级光照

Atom编辑器入门到精通 Atom使用进阶

Atom编辑器入门到精通 Atom使用进阶