以前,有位大佬和我说过这么一句话:"网络知识在必定程度上决定了你的上限"。前端
对HTTP只知其一;不知其二的我,上限真的这么低吗...就不能花点时间好好整理整理吗 🤔️?git
此次请给霖呆呆一个机会,跟着个人脚步👣从1开始学习它。另外我整理的HTTP系列基本都会附有一个面试时的浅答与深答的的配套答案,浅答是为了让大家更好的记住,深答保证你确实理解了浅答中的知识点。github
整个系列下来,让咱们完全 Shutdown HTTP !!!💪面试
系列思惟导图:数据库
系列目录:浏览器
全部文章内容均被收入GitHub我的博客:niubility-coding-js 快来给我Star呀😊~缓存
经过阅读本篇文章你能够学习到:安全
(请注意,带有🌟标示的都是必需要掌握的哦)服务器
HTTP协议(HyperText Transfer Protocol,超文本传输协议)是因特网上应用最为普遍的一种网络传输协议。markdown
设计HTTP最初的目的是为了提供一种发布和接收HTML页面的方法,它是一个基于 TCP/IP 通讯协议来传输数据的应用层协议。
要注意的点就是:
【面试时问起:一句话概述HTTP协议】🌟🌟🌟🌟
「HTTP 是一个在计算机世界里专门在两点之间传输文字、图片、音频、视频等超文本数据的约定和规范。」
(HTTP一般跑在TCP/IP协议栈
之上,依靠IP协议实现寻址和路由
、TCP协议实现可靠数据传输
、DNS协议实现域名查找
、SSL/TLS协议实现安全通讯
。固然,WebSocket、HTTPDNS依赖于HTTP。——「进击的前端工程师」HTTP的世界观(附HTTP/3中文翻译)-童欧巴)
处于 TCP/IP 网络分层模型中的第一层「应用层」。
应用层的其它协议还有:
【面试时问起通常答前面三个就够了】🌟🌟
常问知识点,重要指数:🌟🌟🌟🌟🌟
若是还要的话,能够答一下「持久链接」:
(另外其实还有一个管线化的特色,同时并行发送多个请求,而没必要等前一个请求完毕才能发送下一个。可是由于各类缘由被各大厂商废弃了)
常问知识点,重要指数:🌟🌟🌟🌟🌟
简单来讲:
详细来讲:
常问知识点,重要指数:🌟🌟🌟🌟🌟
GET:获取资源,幂等操做
HEAD:获取报文首部,和GET很像可是不返回报文主体,幂等操做
POST: 建立或更新资源,非幂等操做
PUT: 建立或更新资源自己,幂等操做
PATCH:对资源进行局部更新,非幂等操做
DELETE:删除资源,和PUT功能相反,幂等操做
OPTIONS:查询服务器端支持的HTTP方法种类(幂等操做):
请求 | OPTIONS * HTTP/1.1 Host: lindaidai.wang |
---|---|
响应 | HTTP/1.1 200 OK Allow: GET, POST, HEAD, OPTIONS (返回服务器支持的方法) |
CONNECT:创建链接隧道,用于代理服务器,幂等操做
TRACE:追踪请求,查询发出去的请求是怎样被加工/篡改的,幂等操做。容易引起XST跨站追踪攻击。
重要指数:🌟🌟🌟🌟
(先让咱们来了解一下它的概念)
这东西其实很好理解,你只要记住:若是一个方法重复执行屡次,产生的效果是同样的,那么这个方法就是幂等的。「它本质上意味着成功执行请求的结果与其执行次数无关。」
让咱们来具体看看每一项的分析:
http://lindaidai.wang/account/123
,不会改变资源的状态,不管是调用一次仍是N次都没有反作用。可是要注意了,这里指的是「调用多少次都没有反作用」,而不是每次GET的结果都相同。由于你想一想有可能直接去改了数据库的这条数据,那么下次获取到的可能就不相同了,可是它自己并无产生反作用,因此知足幂等。POST表示建立资源,PUT表示更新资源
;可是实际上它们均可用于建立和更新资源,只不过本质的差异就在于幂等性上。POST所对应的URI并不是建立资源的自己,而是「资源的接收者」。例如:POST http://lindaidai.wang/articles
的语义是在http://lindaidai.wang/articles
下建立一篇帖子,HTTP响应中应包含帖子的建立状态以及帖子的URI。两次相同的POST请求会在服务器端建立两份资源,它们具备不一样的URI,因此POST是「非幂等」的。PUT http://lindaidai.wang/accout/321
的语义是建立或者更新ID为321的帖子。第一次PUT方法执行以后,其在服务器上生成的资源,不能被后续的PUT方法更改,因此对同一URI进行屡次PUT的反作用和一次PUT是相同的,于是它是「幂等」的。DELETE http://lindaidai.wang/accout/321
调用一次和调用N次对系统产生的反作用是相同的,都是为了删掉ID为321的帖子。所以,调用者能够屡次调用或刷新页面而没必要担忧引发错误。【面试时答法】
一个方法是否是幂等,其实就是判断一个方法重复执行屡次,产生的效果是否是同样的,若是是幂等的话,它本质上意味着成功执行请求的结果和它的执行次数无关。我所知道的,只有「POST」和「PATCH」是非幂等的,其它都是幂等操做。
不用我多说,常问知识点,重要指数:🌟🌟🌟🌟🌟
(这里我用的是三元总结的一份答案+本身的一些理解)
(这时候面试官可能还会追加着问你:既然POST要分为两个TCP数据包发送,那GET是否是会比POST更有效啊)
你能够这样回答:
当服务端收到不支持的方法时,会返回 405 Method Not Allowed
,而且会把全部支持的方法写入响应报文首部字段Allow
中返回。
重要指数:🌟🌟🌟🌟🌟
(又是个硬核的知识点啊...这里霖呆呆就只列举一些经常使用的)
「请求已经接收到,须要进一步处理才能完成,可是HTTP/1.0 不支持。」
101 Switching Protocols
:在HTTP升级为WebSocket时,若是服务器赞成变动,则返回 101。「成功处理请求。」
200 OK
:请求成功,一般返回的数据中带有响应体。204 No Content
:意思和200
同样,不过返回的数据中不带有响应体。206 Partial Content
:客户端进行了范围请求且服务端正常处理,响应报文的首部应该还有Content-Range
字段指定实体的范围。使用场景为HTTP分块下载和断点续传。「重定向状态,资源位置发生变更,须要从新请求。」
301 Moved Permanently
:永久重定向,最新的URI为响应报文首部的 Location
字段。场景是:例如你的网站换了地址了,以前的地址不用了,若用户仍是从以前的地址进的话则会返回301
且在Location
中带上最新的URI。且浏览器默认会作缓存优化,减小服务器压力,在第二次访问的时候自动访问重定向的那个地址。302 Found
:临时重定向,和301
不一样,它表示请求的资源临时被移动到了别的URI上,由于是暂时的,因此不会被缓存。303 See Other
:临时重定向,请求的资源临时被移动到了别的URI上,可是明确表示客户端应该使用GET方法获取资源。304 Not Modefied
:客户端带条件请求时虽未知足条件可是也容许返回该资源,它虽然被划分在3xx
中,但其实和重定向没有关系。场景例如:协商缓存成功就会返回304 Not Modefied
,表示请求的资源在服务器上并未发送改变,告诉请求者可使用缓存。(能够看个人这篇文章哦《霖呆呆你来讲说浏览器缓存吧》)307 Temprary Redirect
:临时重定向,可是比302
更加明确,重定向的请求方法和实体都不容许变更。场景例如:HSTS
协议,强制客户端使用https
创建链接,好比你的网站从HTTP
升级到了HTTPS
,而你仍是经过http://xxx
访问的话,就会返回307 Internal Redirect
。(能够试一下juejin.cn)三种临时重定向简单比较:
302 Found
,基本的临时重定向303 See Other
,明确表示客户端应该使用GET
方法307 Temprary Redirect
,请求方法和实体都不容许变更「客户端出现错误。」
400 Bad Request
:请求报文中存在语法错误,可是没有具体指出是哪里。401 Unauthorized
:须要有经过HTTP认证的认证信息或者表示用户认证失败。403 Forbidden
:请求资源被拒绝,缘由是:好比法律禁止、信息敏感。404 Not Found
:请求资源未找到,表示没在服务器上找到相应的资源。「服务端出现错误。」
500 Internal Server Error
:服务器内部错误,可是没有具体指出是哪里,和400
有点像。501 Not Implemented
:表示客户端请求的功能还不支持502 Bad GateWay
:服务器自身是正常的,可是代理服务器没法获取到合法响应(点外卖时外卖小哥没送)503 Service Unavailable
:服务器内部处于超负载状态或进行停机维护(就像是本店今天不开张)你盼世界,我盼望你无bug
。这篇文章就介绍到这里。
能够发现,在基础篇中,主要的都是一些概念题,花个10分钟左右就能看完了。不须要咱们像学习 RSA握手、ECDHE握手、数字签名那些知识点同样,拼命的理解。更多的都是一些硬核知识,须要咱们紧紧记住。
这个系列文章的最后我都会送给你们一段情话来表达我对你们的感谢:
"世界上有两句语言最浪漫动人"
"第一句是 “我爱你”"
"第二句是 “你写的文章真好看”"
"看官你看这样好很差?"
"之后您说第二句"
"而后我说第一句"
啊啊啊啊...太提莫的撩了我都受不了我本身...
喜欢「霖呆呆」的小伙还但愿能够关注霖呆呆的公众号 LinDaiDai
或者扫一扫下面的二维码👇👇👇.
我会不定时的更新一些前端方面的知识内容以及本身的原创文章🎉
你的鼓励就是我持续创做的主要动力 😊.
相关推荐:
《【建议星星】要就来45道Promise面试题一次爽到底(1.1w字用心整理)》
《【建议👍】再来40道this面试题酸爽继续(1.2w字用手整理)》
《【何不三连】比继承家业还要简单的JS继承题-封装篇(牛刀小试)》
《【何不三连】作完这48道题完全弄懂JS继承(1.7w字含辛整理-返璞归真)》
《【精】从206个console.log()彻底弄懂数据类型转换的前世此生(上)》
本文使用 mdnice 排版