HTTP

简介

HTTP是的数据通信的基础。设计HTTP最初的目的是为了提供一种发布和接收HTML页面的方法。想象一个场景,当两个电脑进行通信的时候(发送请求和响应请求),如果两个都用自己的方式去理解对方,这不就乱套了么?所以需要一个规则来规定他们通信时候每句话、符号、数字所表示的意义是什么。这就是HTTP的由来,这就像玩破冰游戏时候一开始裁判所说的规则一样,只是HTTP这个规则比较长而已。

命令行

说到HTTP,就离不开发送请求。当我们每次在浏览器访问网站的时候,其实就在发请求:输入www.baidu.com的时候发的是GET请求,点击登录的时候发的是POST请求等等。浏览器不过是可以将返回的页面解析并显示出来,而这些请求都是特定的请求,如果想发特定的呢?比如我就想发一个123给www.baidu.com呢?这个时候就可以用命令行去完成了。

上手

$ curl -- "https://www.baidu.com"

你会看到输出的是一堆HTML,这就是最简单的对百度网页的GET请求。

查看详细的Request和Response

单单看返回的HTML内容没什么意义,我们其实想更深入地去看我们到底发了什么给百度,这里的 -v 是指 verbose ,就是啰嗦地给你说整个 request 和 response 的内容

$ curl -v -- "https://www.baidu.com"

你会看到如下内容

* Rebuilt URL to: www.baidu.com/
*   Trying 104.193.88.123...
* TCP_NODELAY set
* Connected to www.baidu.com (104.193.88.123) port 80 (#0)
> GET / HTTP/1.1
> Host: www.baidu.com
> User-Agent: curl/7.54.0
> Accept: */*
>
< HTTP/1.1 200 OK
< Accept-Ranges: bytes
< Cache-Control: private, no-cache, no-store, proxy-revalidate, no-transform
< Connection: Keep-Alive
< Content-Length: 2381
< Content-Type: text/html
< Date: Sat, 13 Oct 2018 03:25:42 GMT
< Etag: "588604eb-94d"
< Last-Modified: Mon, 23 Jan 2017 13:28:11 GMT
< Pragma: no-cache
< Server: bfe/1.0.8.18
< Set-Cookie: BDORZ=27315; max-age=86400; domain=.baidu.com; path=/
<

解释一下

  1. 星号 * 开头的是注释,可以不看
  2. 大于号 > 是你的请求内容
  3. 小于号 < 是对方对你请求的响应内容
  4. 后面是响应内容,这里就不展示出来了

发送其他请求

接着我们来试试发送一个POST请求,这里的 -X 是指 request,读一下request的英文是不是有点X的音?

$ curl -X POST -v -- "https://www.baidu.com"

按下回车后,看到了和之前不一样的响应内容,内容里所说的就是找不到网址。如果想给网站加一些POST的数据可以这么写,这里的是 -d 是指 data,就是要发送的数据

$ curl -X POST -v -d "12345" -- "www.baidu.com"

注意看请求的Content-Type属性

> Content-Length: 5 -> 就是我们的"12345"

Header

当我们发送一个请求的时候,有时候要告诉对方一些有用的信息,比如我拿什么软件给你发的、发多少东西给对方等,这些东西一般写在请求头里。就像我们给别人送信一样,请求头就是我们的信封。

可以在命令中加入 -H "xxx: yyy" 到请求头中,注意:加入请求头的内容必需是 key: value 的形式

curl -X POST -v -H "xxx: yyy" -- "www.baidu.com"

再看我们发送请求的请求头,会在最后多了一行

> xxx: yyy

请求格式

玩了上面的命令,可能你都大概了解了HTTP的套路了,下面先对HTTP请求的套路总结一下

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. 第一部分包括了用什么方法(动词)用什么版本(版本)的什么协议(协议)向谁(路径)发送的请求
  3. 第二部分包括了这封信(请求)的信封上面的内容(请求头)
  4. 第三部分是一个回车换行符,用来分割第二部分和第四部分
  5. 第四部分是发送的数据

注意

  1. 这里的路径包括「查询参数」,但不包括「锚点」
  2. 可用的请求方法有 GET POST PUT PATCH DELETE HEAD OPTIONS 等
  3. 如果你没有写路径,那么路径默认为 /
  4. 第二部分中的 Content-Type 标注了第 4 部分的格式

响应格式

下面说下响应的格式

1 协议/版本号 状态码 状态解释
2 Key1: value1
2 Key2: value2
2 Content-Length: 17931
2 Content-Type: text/html
3
4 要下载的内容
  1. 第一部分首先说明我用什么版本(版本)的什么协议(协议)给你发送一个接收状态,状态码都有对应的解释,后面的状态解释算是一个详细的说明
  2. 第二部分包括了响应的信息,但是不是主要内容,只是此次响应的基本信息
  3. 第三部分也是一个回车换行符,用来分割第二部分和第四部分
  4. 第四部分才是响应的内容,一般为JSON数据或者HTML页面

用Chrome来查看网络请求

如果你觉得用命令行看请求太费劲,可以用Chrome来查看请求和响应的内容,用GUI看毕竟清析一点。

  1. 首先右键点击审查
  2. 打开 Network
  3. 输入网址
  4. 选中第一个响应
  5. 查看 Response Headers,点击「view source」
  6. 你会看到响应的前两部分
  7. 查看 Response 或者 Preview,你会看到响应的第 4 部分
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,542评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,596评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,021评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,682评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,792评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,985评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,107评论 3 410
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,845评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,299评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,612评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,747评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,441评论 4 333
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,072评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,828评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,069评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,545评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,658评论 2 350

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,637评论 18 139
  • 国家电网公司企业标准(Q/GDW)- 面向对象的用电信息数据交换协议 - 报批稿:20170802 前言: 排版 ...
    庭说阅读 10,934评论 6 13
  • 什么是HTTP? 在Web应用中,服务器把网页传给浏览器,实际上就是把网页的HTML代码发送给浏览器,让浏览器显示...
    Frank_io阅读 274评论 0 0
  • Spring Web MVC Spring Web MVC 是包含在 Spring 框架中的 Web 框架,建立于...
    Hsinwong阅读 22,366评论 1 92
  • 很荣幸能参加2018年青椒计划,在这一个月来,我自从参加青椒计划来,都准时参加看直播,在直播过程中认真做好笔...
    德宏1244江海船阅读 190评论 2 2