HTTP的请求与响应

HTTP(Hyper Text Transfer Protocol)超文本传输协议。是用于从WWW服务器传输超文本到本地浏览器的传输协议。它采用了请求与响应的模式。今天就来总结一下关于HTTP请求与响应的知识。

整个过程如下:

  1. 浏览器负责发起请求。
  2. 服务器在80端口接收请求。
  3. 服务器负责返回内容(响应)
  4. 浏览器负责下载响应内容。

一、 请求

1.请求示例:
在Git中输入curl指令,获取网页内容。

curl -s -v -H " xxx: Hello World " -- "https://www.baidu.com"

请求内容如下

GET / HTTP/1.1
Host: www.baidu.com
User-Agent: curl/7.61.1
Accept: */*
xxx: Hello World
  1. 将请求方式改为POST。示例:
curl -X POST -s -v -H "sw: Hello World" -- "https://www.baidu.com"

请求内容如下:

 POST / HTTP/1.1
 Host: www.baidu.com
 User-Agent: curl/7.61.1
 Accept: */*
sw: Hello World

3.请求方式为post并且在该请求中发送指定的数据,示例:

curl -X POST -d "123" -s -v -H "sw: Hello World" -- "https://www.baidu.com"

请求内容如下:

POST / HTTP/1.1 
Host: www.baidu.com
User-Agent: curl/7.61.1
Accept: */*
 sw: Hello World
Content-Length: 3
Content-Type: application/x-www-form-urlencoded

[3 bytes data] // -d: 123
  1. 请求的具体格式:
    由以下四部分组成
    第一部分: 动词 路径 协议/版本号
    第二部分:
    Key1: value1
    Key2: value2
    Key3: value3
    Content-Length: 3
    Content-Type: application/x-www-form-urlencoded
    第三部分:回车
    第四部分:需要上传的数据

常见的几个动词如下:
GET:请求指定的页面信息,并返回实体主体。
HEAD:只请求页面的首部。
POST: 请求服务器接受所指定的文档作为对所标识的URI的新的从属实体。
PUT: 从客户端向服务器传送的数据取代指定的文档的内容。
DELETE: 请求服务器删除指定的页面。
PATCH: 实体中包含一个表,表中说明与该URI所表示的原内容的区别。
OPTIONS: 允许客户端查看服务器的性能。

  1. 如何在Chrome中查看HTTP请求内容?
    (1)打开浏览器自带的开发者工具查看(这里以百度为例子),进入Network中查看。
    (2)输入完整的URL地址。
    (3)在Network中查看第一个请求的request,并且点击view source就能看到以下截图。


    Chrome中查看请求内容

二、响应

  1. 与上一章请求示例1中对应的响应如下:
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: Sun, 14 Oct 2018 11:25:30 GMT
Etag: "58860429-98b"
Last-Modified: Mon, 23 Jan 2017 13:24:57 GMT
Pragma: no-cache
Server: bfe/1.0.8.18
Set-Cookie: BDORZ=27315; max-age=86400; domain=.baidu.com; path=/

{ [2443 bytes data]

需要说明的是最后一行显示的是要下载的内容,这里进行了省略。

  1. 与示例2对应的响应如下:
 HTTP/1.1 302 Found
 Connection: Keep-Alive
 Content-Length: 17931
 Content-Type: text/html
 Date: Sun, 14 Oct 2018 11:30:29 GMT
 Etag: "54d9748e-460b"
 Server: bfe/1.0.8.18

{ [3824 bytes data]
  1. 响应的格式

第一部分:协议/版本号 状态码 状态解释
第二部分:
Key1: value1
Key2: value2
Content-Length: 17931
Content-Type: text/html

常见的几个状态码:
1xx:这一类型的状态码,代表请求已被接受,需要继续处理。
2xx:这一类型的状态码,代表请求已成功被服务器接收、理解、并接受。
3xx:这类状态码代表需要客户端采取进一步的操作才能完成请求。
4xx:客户端错误,这类的状态码代表了客户端看起来可能发生了错误,妨碍了服务器的处理。

  1. 用Chrome查看响应
    (1)打开开发者工具中的Network
    (2)输入网址并选中第一个响应
    (3)查看Response Headers,点击view source就会看到响应的前两部分。
    (4)查看Response或Preview看到第四部分。


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

推荐阅读更多精彩内容

  • Server + Client + HTTP 浏览器负责发起请求 服务器在 80 端口接收请求 服务器负责返回内容...
    ScottWalker阅读 583评论 0 0
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,673评论 18 139
  • 对于浏览器访问网站的过程中发生的请求与响应的相关知识 一、 浏览器与服务器是如何沟通的 浏览器负责发起请求 服务器...
    抱着熊喵啃什么阅读 307评论 0 0
  • Server(服务器)+Client(客户端)+HTTP(超文本传输协议) HTTP的作用就是指导浏览器与服务器进...
    还是流星拳比较好阅读 400评论 0 0
  • 窗外,天气很好。我家住在靠近马路边的,七楼,听说声音是向上传的,所以总感觉汽车行人好像也从我床前路过了。 我习惯性...
    796a3c1c25df阅读 193评论 0 0