前端学习笔记

HTTP 请求与响应

2019-08-11  本文已影响1人  _ClariS_

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的常见组成

注意:

DNS(Domain Name System)

域名系统,作用是

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 的作用就是指导浏览器和服务器如何进行沟通。

总的来说,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 本质上都是 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 要上传的数据

注意:

用 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 要下载的内容

注意:

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

用 Chrome 查看响应

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

  

上一篇 下一篇

猜你喜欢

热点阅读