一起来了解HTTP的基本知识

一起来了解HTTP的基本知识

在正式开始学习之前,我们先来了解一下HTTP的大概历史

历史

1990年前的历史

上世纪九十年代前,互联网还没有被发明出来,那时候的网络基本以发邮件(Email1965年发明)等形式简单实用

1990年后的世界

  • Tim Berners-Lee(下文中称为李爵士) 在 1989 年至 1992 年间,发明了 WWW(World Wide Web)
  • 主要包含三个概念
    URI,俗称网址
    HTTP,两个电脑之间传输内容的协议
    HTML,超级文本,主要用来做页面跳转
    URL 的作用是能让你访问一个页面,HTTP 的作用是让你能下载这个页面,HTML 的作用是让你能看懂这个页面
    完美搭配干活不累
  • 李爵士除了发明了这些概念,还:

发明了第一个服务器
发明了第一个浏览器
写出了第一个网页

这老头好强有木有!~

因此他获得了计算机科学领域最富盛名的的奖项——图灵奖

万维网之父Tim Berners-Lee获图灵奖:奖金100万美元

URI(Uniform Resource Identifier)是一个用于标识某一互联网资源名称的字符串

URI 分为 URL 和 URN,我们一般使用 URL 作为网址

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

例如:www.baidu.com
一级域名com
二级域名baidu
三级域名www

了解下DNS

要了解HTTP就不得不了解一下DNS

它的作用其实非常简单,就是根据域名查出IP地址

举例来说,如果你要访问域名 www.glrssn.com,首先要通过 DNS 查出它的IP地址是 xx.xxx.xxx.xxx

  • 输入域名
  • 输出IP

Server + Client + HTTP组合

浏览器负责发起请求
服务器在 80 端口接收请求
服务器负责返回内容(响应)
浏览器负责下载响应内容
HTTP 的作用就是指导浏览器(Clinet)和服务器(Server)如何进行沟通

请求示例一

url -s -v -H "Frank: xxx" -- "https://www.baidu.com"

请求的内容为
GET / HTTP/1.1
Host: www.baidu.com
User-Agent: curl/7.54.0
Accept: */*
Frank: xxx

请求示例二

curl -X POST -s -v -H "Frank: xxx" -- "https://www.baidu.com"

请求的内容为
POST / HTTP/1.1
Host: www.baidu.com
User-Agent: curl/7.54.0
Accept: */*
Frank: xxx

请求的格式

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 部分的格式

用 Chrome 发请求

打开 Network
地址栏输入网址
在 Network 点击,查看 request,点击「view source」
点击「view source」
点击「view source」
点击「view source」
终于点了?可以看到请求的前三部分了
如果有请求的第四部分,那么在 FormData 或 Payload 里面可以看到

响应

响应的格式

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

状态码

状态码要背,是服务器对浏览器说的话,也是一些面试官会经常提问的一个知识点

1xx 不常用
2xx 表示成功
3xx 表示滚吧
4xx 表示你丫错了
5xx 表示好吧,我错了

状态码查询

用 Chrome 查看响应

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

好啦~ 以上就是HTTP的一些基础知识了,很感谢你能够看到这里,同时希望你能够有些收获

博客之初会分享一些相对基础的一些知识,希望同大家一起巩固一下基础知识,从而在以后的学习中能够更加的游刃有余。

就这样啦

晚安,少年~