HTTP 请求与响应

作者: _ClariS_ | 来源:发表于2019-08-11 12:58 被阅读1次

URI(Uniform Resource Identifier)

统一资源标识符,俗称网址
URI 分为 URL 和 URN,我们一般使用 URL 作为网址。

URN(Uniform Resource Name)

唯一确定的一个名称

例如,ISBN: 9787115275790 就是一个 URN,通过 URN 你可以确定一个「唯一的」资源,ISBN: 9787115275790 对应的资源的是《JavaScript 高级程序设计(第三版)》这本书。你去是介绍任何一个图书馆、书店,他们都知道是这本书。

URL(Uniform Resource Locator)

唯一确定一个位置

例如,https://www.baidu.com/s?wd=hello&rsv_spt=1#5 就是一个 URL,通过 URL 你可以确定一个「唯一的」地址(网址)。

URL的常见组成

注意:

  • www.baidu.combaidu.com 是两个不同的域名,前者是一个三级域名,后者是一个两级域名,它们共有一个二级域名 baidu.com
  • 图中并没有包括「端口」,完整的 URL 包括:协议、域名、端口号、路径、查询字符串、锚点

DNS(Domain Name System)

域名系统,作用是

  • 输入域名
  • 输出对应的 IP

nslookup baidu.com
ping baidu.com

问:如果想让 baidu.com 域名指向 127.0.0.1 这个 IP 应该怎么做?

答:修改本地 hosts 文件,设置 127.0.0.1 baidu.com

修改本地hosts的IP

Server + Client + HTTP

服务器与浏览器的交互
  • 浏览器负责发起请求
  • HTTP 的默认服务端口是 80,服务器在 80 端口接收请求
  • 服务器负责返回内容(响应)
  • 浏览器负责下载响应内容

HTTP 的作用就是指导浏览器和服务器如何进行沟通。

总的来说,URL 的作用是能让你访问一个页面,HTTP 的作用是让你能下载这个页面,HTML 的作用是让你能看懂这个页面。

请求示例

  1. 输入 curl -s -v -H "zzzzzzz: xxx" -- "https://www.baidu.com"
    用 curl 创造一个 get 请求,并得到响应

请求的内容为

> GET / HTTP/1.1
> Host: www.baidu.com
> User-Agent: curl/7.64.0    用什么软件发起的响应
> Accept: */*     接受返回的任何内容
> zzzzzzz: xxx
>
  1. 输入 curl -X POST -s -v -H "zzzzzzz: xxx" -- "https://www.baidu.com"
用 curl 创造一个 post 请求,并得到响应

请求的内容为

> POST / HTTP/1.1
> Host: www.baidu.com
> User-Agent: curl/7.64.0
> Accept: */*
> zzzzzzz: xxx
>
  1. 输入 curl -X POST -d "1234567890" -s -v -H "zzzzzzz: xxx" -- "https://www.baidu.com"
用 curl 创造一个带数据的 post 请求,并得到响应

请求的内容为

> POST / HTTP/1.1
> Host: www.baidu.com
> User-Agent: curl/7.64.0
> Accept: */*
> zzzzzzz: xxx
> Content-Length: 10    上传的内容的长度
> Content-Type: application/x-www-form-urlencoded    上传的内容的类型
>
1234567890   要上传的数据或文件

这里简单说一下 get 和 post 的区别:

  • get 为获取内容/信息
  • post 为上传内容/信息
  • 用 get 来上传内容,一般服务器不接受

get 和 post 本质上都是 TCP 链接,并无差别。但是由于 HTTP 的规定和浏览器/服务器的限制,导致他们在应用过程中体现出一些不同。详细内容见文章 get 和 post 的区别

请求的格式

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 要上传的数据

注意:

  • 请求最多包含四部分,最少包含三部分。(也就是说第四部分可以为空)
  • 第三部分永远都是一个回车(\n)
  • 动词有 GET(获取)、POST(上传)、PUT(整体更新)、PATCH(局部更新)、DELETE、HEAD、OPTIONS 等
  • 这里的路径包括「查询参数」,但不包括「锚点」
  • 如果你没有写路径,那么路径默认为 /
  • 第 2 部分中的 Content-Type 标注了第 4 部分的格式
  • HTTP,两个电脑之间传输内容的协议
  • HTML,超级文本,主要用来做页面跳转

用 Chrome 发请求

  1. 打开 Network
  2. 地址栏输入网址
  3. 在 Network 点击,查看 request,点击「view source」
  4. 点击「view source」
  5. 如果有请求的第四部分,那么在 FormData 或 Payload 里面可以看到
步骤 点击 view source 查看结果

响应示例

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

< 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, 11 Aug 2019 03:53:06 GMT
< Etag: "5886041d-98b"
< Last-Modified: Mon, 23 Jan 2017 13:24:45 GMT
< Pragma: no-cache
< Server: bfe/1.0.8.18
< Set-Cookie: BDORZ=27315; max-age=86400; domain=.baidu.com; path=/
<
<!DOCTYPE html>
<!--STATUS OK--><html> <head> 后面太长,省略了……
< HTTP/1.1 302 Found
< Connection: Keep-Alive
< Content-Length: 17931
< Content-Type: text/html
< Date: Sun, 11 Aug 2019 03:59:13 GMT
< Etag: "54d9749e-460b"
< Server: bfe/1.0.8.18
<
<html>
<head>
<meta http-equiv="content-type" content="text/html;charset=utf-8"> 后面太长,省略了……

注意:

  1. GET 请求和 POST 请求对应的响应可以一样,也可以不一样
  2. 响应的第四部分可以很长很长很长

响应的格式

1 协议/版本号 状态码 状态解释
2 Key1: value1
2 Key2: value2
2 Content-Length: 17931
2 Content-Type: text/html
3
4 要下载的内容

注意:

  • 状态解释没什么用
  • 第 2 部分中的 Content-Type 标注了第 4 部分的格式
  • 第 2 部分中的 Content-Type 遵循 MIME 规范

状态码------是服务器对浏览器说的话

  • 1xx ——信息,服务器收到请求,需要请求者继续执行操作(不常用)
  • 2xx ——成功,操作被成功接收并处理
    200(成功)服务器已成功处理了请求。 通常,这表示服务器提供了请求的网页,一般用于 GET 与 POST 请求。
    204(无内容)服务器成功处理了请求,但没有返回任何内容。
  • 3xx ——重定向,需要进一步的操作以完成请求
    301(永久移动)请求的网页已永久移动到新位置。 服务器返回此响应(对 GET 或 HEAD 请求的响应)时,会自动将请求者转到新位置。
    302(临时移动)服务器目前从不同位置的网页响应请求,但请求者应继续使用原有位置来进行以后的请求。
    304(未修改)自从上次请求后,请求的网页未修改过。 服务器返回此响应时,不会返回网页内容。
  • 4xx ——客户端错误,请求包含语法错误或无法完成请求
    404(未找到)服务器无法根据客户端的请求找到资源(网页)。通过此代码,网站设计人员可设置"您所请求的资源无法找到"的个性页面
  • 5xx ——这些状态代码表示服务器在尝试处理请求时发生内部错误。 这些错误可能是服务器本身的错误,而不是请求出错。
    500(服务器内部错误)服务器遇到错误,无法完成请求。
    502(错误网关)服务器作为网关或代理,从上游服务器收到无效响应。

用 Chrome 查看响应

  1. 打开 Network
  2. 地址栏输入网址
  3. 选中第一个响应
  4. 查看 Response Headers,点击「view source」
  5. 你会看到响应的前两部分
  6. 查看 Response 或者 Preview,你会看到响应的第 4 部分

  

相关文章

  • HTTP入门(二):用Chrome开发者工具查看 HTTP 请求

    HTTP入门(二):用Chrome开发者工具查看 HTTP 请求与响应 本文简单总结HTTP的请求与响应。本文主要...

  • http协议

    1-http 数据结构 http 请求格式:(请求与响应有细微的差别) http 响应格式 抓取包: 2-http...

  • HTTP 请求与响应

    HTTP简介 超文本传输协议(英文:HyperText Transfer Protocol,缩写:HTTP)是一种...

  • HTTP请求与响应

    1.服务器与浏览器的交互 HTTP请求与响应通过Server+Client+HTTP实现: 客户端( 浏览器)负责...

  • HTTP 请求与响应

    HTTP 请求包括哪些部分,如何用Chrome开发者工具查看 HTTP 请求内容 HTTP 响应包括哪些部分,如何...

  • HTTP请求与响应

    Server + Client + HTTP 浏览器负责发起请求 服务器在80端口接收请求 服务器负责返回内容(响...

  • http请求与响应

    HTTP请求 一个HTTP请求至少包括三部分,最多包括四部分 第一部分:动词 路径 ...

  • HTTP、请求与响应

    HTTP全称HyperText Transfer Protocol,超文本传输协议。在维基百科上的定义为:H...

  • http请求与响应

    http是一种超文本传输协议(HyperText Transfer Protocol),是目前使用最广的网络传输协...

  • HTTP请求与响应

    HTTP HTTP:Hyper Text Transfer Protocol(超文本传输协议)的缩写,HTTP是一...

网友评论

    本文标题:HTTP 请求与响应

    本文链接:https://www.haomeiwen.com/subject/oadjjctx.html