HTTP的请求与响应

Server + Client + HTTP

服务器与浏览器的交互
  • 浏览器负责发起请求
  • 服务器在 80 端口接收请求
  • 服务器负责返回内容,即响应
  • 浏览器负责下载响应内容
    HTTP 的作用就是指导浏览器和服务器如何进行沟通。

一、请求


1. 请求示例

  1. curl -s -v -H "xxx: yyy" -- "https://www.baidu.com"
    请求内容
GET / HTTP/1.1
Host: www.baidu.com
User-Agent: curl/7.60.0
Accept: */*
xxx: yyy
  1. curl -X POST -s -v -H "xxx: yyy" -- "https://www.baidu.com"
    请求内容
POST / HTTP/1.1
Host: www.baidu.com
User-Agent: curl/7.60.0
Accept: */*
xxx: yyy
  1. curl -X POST -d "x12345" -s -v -H "xxx: yyy" -- "https://www.baidu.com"
    请求内容
POST / HTTP/1.1
Host: www.baidu.com
User-Agent: curl/7.60.0
Accept: */*
xxx: yyy
Content-Length: 6
Content-Type: application/x-www.form-urlencoded

x12345

2. 请求的格式

一 动词 路径 协议/版本号
二 Key1: value1
   Key2: value2
   Key2: value3
   Content-Type: application/x-www-form-urlencoded
   Host: www.baidu.com
   User-Agent: curl/7.60.0
三 回车(\n)
四 要上传的数据
  1. 请求最多包含四部分,最少包含三部分,第四部分可以为空
  2. 第三部分永远都是一个回车,用于分隔第二和第四部分
  3. 动词有 GET\POST\PUT\PATCH\DELETE\HEAD\OPTIONS 等
  4. 这里的路径包括 [查询参数],但不包括 [锚点]
  5. 如果你没有写路径,默认路径为 /
  6. 第二部分中的Content-Type 标注了第四部分的格式

3. 使用Chrome开发者工具查看 HTTP 请求内容

  1. 打开Network(单击鼠标右键、F12、Ctrl + Shirft + I )
  2. 地址栏输入网址
  3. 点开Network,查看 request,点击 [view source]
  4. 点击 [view source],点击 [view source],点击 [view source]
  5. 如果有请求的第四部分,在FormData 或 Payload可以看到

二、响应


1. 响应示例

  1. curl -s -v -H "xxx: yyy" -- "https://www.baidu.com"
< HTTP/1.1 200 OK
< Accept-Ranges: bytes
< Cache-Control: private, no-cache, no-store, proxy-revalidate, no-tra                                                                               nsform
< Connection: Keep-Alive
< Content-Length: 2443
< Content-Type: text/html
< Date: Sun, 26 Aug 2018 11:37:04 GMT
< Etag: "588603ec-98b"
< Last-Modified: Mon, 23 Jan 2017 13:23:56 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>
后面省略......
  1. curl -X POST -s -v -H "xxx: yyy" -- "https://www.baidu.com"
< HTTP/1.1 302 Found
< Connection: Keep-Alive
< Content-Length: 17931
< Content-Type: text/html
< Date: Sun, 26 Aug 2018 11:42:16 GMT
< Etag: "54d97488-460b"
< Server: bfe/1.0.8.18
<html>
<head>
<meta http-equiv="content-type" content="text/html;charset=utf-8">
后面省略......
  1. GET请求和POST请求对应的响应可以一样,也可以不一样
  2. 响应的第四部分可以很长很长

2. 响应的格式

一   协议/版本号 状态码 状态解释
二   Key1: value1
     Key2: value2
     Key3: value3
     Content-Length: 17931
     Content-Type: text/html
三   回车
四   要下载的内容
  • 状态码要背,是服务器对浏览器说的话
    • 1xx 不常用
    • 2xx 表示成功
    • 3xx 表示滚吧
    • 4xx 表示你丫错了
    • 5xx 表示好吧,我错了
  • 状态解释没什么用
  • 第二部分的Content-Type 标注了第四部分的格式,且遵循 MIME 规范

3. 使用Chrome开发者工具查看 HTTP 响应内容

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

三、补充

URL 全称: Uniform Resource Locator(统一资源定位符)
HTML 全称:Hypertext Markup Language(超文本标记语言)
HTTP 全称:Hypertext Transfer Protocol(超文本传输协议)
DNS 全称:Domain Name System(域名系统)


URI 分为URI 和 URN。
URL 是一种 URI,就是我们常说的网址。
URL 包括:协议、域名、端口号、路径、查询字符串、锚点

URL常见组成

HTTP 的默认服务端口是:80
DNS 的作用:输入域名,输出对应 IP
我想让 baidu.com 域名指向 127.0.0.1 这个 IP 应该:修改本地 hosts 文件


curl -s -v -- "https://www.baidu.com" 返回的请求是:
GET / HTTP/1.1
Host: www.baidu.com
User-Agent: curl/7.60.0
Accept: */*
回车


一个合法的 HTTP 请求第一行:GET / HTTP/1.1

一个合法的 HTTP 响应第一行: HTTP/1.1 200 OK

一个合法的 HTTP 请求第二部分:
Host: xiedaimala.com
User-Agent: curl/7.60.0
Accept: */*


HTTP 请求中的 Content-Type:表示请求第4部分内容的格式
HTTP 响应中的 Content-Type:表示响应第4部分内容的格式


HTTP 响应中状态码 200:OK 表示请求已成功,请求所希望的响应头或数据体将随此响应返回。实际的响应将取决于所使用的请求方法。在GET请求中,响应将包含与请求的资源相对应的实体。在POST请求中,响应将包含描述或操作结果的实体。


HTTP 响应中状态码 301:Moved Permanently 表示被请求的资源已永久移动到新位置,并且将来任何对此资源的引用都应该使用本响应返回的若干个 URI 之一。


HTTP 响应中状态码 302:Found 表示 Moved Temporarily,要求客户端执行临时的重定向,并且客户端可以继续向原有地址发送以后的请求。


HTTP 响应中状态码 403:Forbidden 表示没有权限访问此站,服务器接收到请求但拒绝提供服务。


HTTP 响应中状态码 404:HTTP 404 或 Not Found 错误信息是 HTTP 的一种“标准回应信息”,此信息代表客户端在浏览网页时,服务器无法正常提供信息,或是服务器无法回应且不知原因。404错误信息可能与“Server Not Found”(无法找到服务器)或其他类似信息产生混淆。


HTTP 响应中状态码 500:Internal Server Error 表示通用错误信息,服务器遇到了一个未曾预料的状况,导致了它无法完成对请求的处理,没用给出具体错误信息。


HTTP 响应中状态码 502:Bad Gateway 表示作为网关或者代理工作的服务器尝试执行请求时,从上游服务器接收到无效的响应。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值