热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

pb9调用http发短信post_深入理解HTTP每个知识点!

ShutdownHTTP系列介绍之前,有位大佬和我说过这么一句话:网络知识在一定程度上决定了你的上限。对HTTP一知半解的我,上限真的

Shutdown HTTP系列介绍

之前,有位大佬和我说过这么一句话:"网络知识在一定程度上决定了你的上限"。

对HTTP一知半解的我,上限真的这么低吗...就不能花点时间好好整理整理吗 ?️?

这次请给霖呆呆一个机会,跟着我的脚步?从1开始学习它。另外我整理的HTTP系列基本都会附有一个面试时的浅答与深答的的配套答案,浅答是为了让你们更好的记住,深答保证你确实理解了浅答中的知识点。

整个系列下来,让我们彻底 Shutdown HTTP !!!?

系列思维导图:

213ae15e15eba03b8400368c8f10e2ba.png

所有文章内容均被收入GitHub个人博客:niubility-coding-js 快来给我Star呀?~

https://github.com/LinDaiDai/niubility-coding-js

本篇目录

通过阅读本篇文章你可以学习到:

  • HTTP概述
  • HTTP特点及缺点
  • HTTP请求方法
  • HTTP状态码

(请注意,带有?标示的都是必须要掌握的哦)

1. HTTP概述

HTTP协议(HyperText Transfer Protocol,超文本传输协议)是因特网上应用最为广泛的一种网络传输协议。

设计HTTP最初的目的是为了提供一种发布和接收HTML页面的方法,它是一个基于 TCP/IP 通信协议来传输数据的应用层协议。

要注意的点就是:

  • 一句话概述HTTP
  • HTTP经典的几个版本
  • HTTP存在的位置

1.1 一句话概述HTTP

【面试时问起:一句话概述HTTP协议】????

「HTTP 是一个在计算机世界里专门在两点之间传输文字、图片、音频、视频等超文本数据的约定和规范。」

(HTTP通常跑在TCP/IP协议栈之上,依靠IP协议实现寻址和路由TCP协议实现可靠数据传输DNS协议实现域名查找SSL/TLS协议实现安全通信。当然,WebSocket、HTTPDNS依赖于HTTP。

1.2 HTTP经典的几个版本

  • 第一版 「HTTP/0.9」「1990年」问世,并没有作为正式的标准被建立。
  • 作为正式的标准被建立是 「HTTP/1.0」,于「1996年5月」发布。(比霖呆呆大了4个月)
  • 目前主流的版本是 「HTTP/1.1」,于「1997年1月」发布。
  • 「2015年5月」 正式发布「HTTP/2」。(不叫HTTP/2.0,是因为标准委员会不打算发布子版本,下一个版本直接是HTTP/3)

1.3 HTTP存在的位置

处于 TCP/IP 网络分层模型中的第一层「应用层」

应用层的其它协议还有:

  • FTP:文件传输协议,用来在客户机和FTP服务器之间传输文件。
  • DNS域名系统:提供域名到IP地址之间的解析服务。
  • SMTP:邮件发送协议,用户通过SMTP服务器发送邮件。
  • DHCP:动态主机配置协议,DHCP服务器为客户机动态分配IP地址。
  • POP3:邮件接收协议,用于从POP3服务器接收邮件。

【面试时问起一般答前面三个就够了】??

2. HTTP特点及缺点

2.1 HTTP特点

常问知识点,重要指数:?????

  1. HTTP协议支持客户端/服务端模式,也是一种请求/响应模式的协议。
  2. 灵活可扩展:一个是语义上的自由,只规定了基本格式,其它的各部分没有严格的限制;第二个它允许传输任意类型的数据对象,例如文本、图片、音频等,传输的类型由Content-Type加以标记。
  3. 可靠传输,HTTP 基于 TCP/IP,因此把这一特性继承了下来。
  4. 无状态,也就是说HTTP请求不具备保存之前发送过的请求或响应的功能,每一次请求都是独立无关的。

如果还要的话,可以答一下「持久连接」:

  • 概念:建立一次TCP连接即可进行多次请求或响应的交互
  • 产生原因:HTTP的初始版本是每进行一次HTTP通信就要断开一次TCP连接,下次再进行的时候又要重新连接断开。再如今请求的资源越来越大,每次请求如果都有无谓TCP连接和断开是很大的开销。
  • 特点:只要有一方没有明确的提出断开连接,则保持TCP连接状态。
  • 优点:减少了TCP连接和断开的造成的额外开销,减轻了服务端的负载,Web页面加载变快
  • 注意点:在HTTP/1.1中所有的连接默认都是持久连接的(也就是首部字段 Connection: keep-alive,若是想要关闭则将值设置为 close),但是HTTP/1.0并未标准化

(另外其实还有一个管线化的特点,同时并行发送多个请求,而不必等前一个请求完毕才能发送下一个。但是因为各种原因被各大厂商废弃了)

2.2 HTTP的缺点

常问知识点,重要指数:?????

简单来说:

  1. 明文传输(不加密),内容可能被窃听。
  2. 无法验证报文的完整性,内容可能被篡改。
  3. 不验证通信方的身份,有可能遭遇伪装。
  4. 无状态,它是缺点也是优点吧,分不同的场景。
  5. 队头阻塞。

详细来说:

  1. 明文传输(不加密),内容可能被窃听。协议里的报文不使用二进制数据,而是文本形式
  2. 无法验证报文的完整性,内容可能被篡改。这里说的完整性也就是指信息的准确度 因为接收方或者发送方没有办法确认对方发送过来的数据在中间有没有被篡改
  3. 不验证通信方的身份,有可能遭遇伪装。因为HTTP协议中不会对通信方进行确认 任何人都可以发送请求,而且服务器它对收到的请求也不会进行确认,只要收到了请求就会返回一个响应(当然这个只是在发送端的IP地址或者端口号没被Web服务器设定限制访问的前提下)
  4. 无状态,不具备保存之前发送过的请求或响应的功能。它是缺点也是优点吧:
  • 对于一些长连接的场景需要保存上下文信息,以免传输重复的数据。
  • 对于一些应用只是为了获取数据不需要保存上下文信息,无状态减少了网络开销。
队头阻塞:
  • 其根本原因在于HTTP是基于 请求-响应 的模型,在同一个TCP长连接中,前一个请求没有得到响应,后面的请求就会被阻塞。
  • 用并发连接 和 域名分片 来解决了这个问题。但并不是从HTTP本身的层面来解决的,只是增加了 TCP 连接,分摊风险而已。
  • HTTP/2中的多路复用从HTTP本身的层面解决了这个问题
  • 和TCP队头阻塞的区别:TCP传输的单位是数据包,它的队头阻塞表示的是前一个报文没有收到便不会将下一个报文上传给HTTP。而HTTP队头阻塞是在 请求-响应 层面,前一个请求还没有处理完,后面的请求就被阻塞。

3. HTTP请求方法

3.1 方法种类

常问知识点,重要指数:?????

  1. GET:获取资源,幂等操作

  2. HEAD:获取报文首部,和GET很像但是不返回报文主体,幂等操作

  3. POST: 创建或更新资源,非幂等操作

  4. PUT: 创建或更新资源本身,幂等操作

  5. PATCH:对资源进行局部更新,非幂等操作

  6. DELETE:删除资源,和PUT功能相反,幂等操作

  7. OPTIONS:查询服务器端支持的HTTP方法种类(幂等操作):

    请求OPTIONS * HTTP/1.1
    Host: lindaidai.wang
    响应HTTP/1.1 200 OK
    Allow: GET, POST, HEAD, OPTIONS
    (返回服务器支持的方法)
  8. CONNECT:建立连接隧道,用于代理服务器,幂等操作

  9. TRACE:追踪请求,查询发出去的请求是怎样被加工/篡改的,幂等操作。容易引发XST跨站追踪攻击。

3.2 HTTP中的幂等是什么意思

重要指数:????

(先让我们来了解一下它的概念)

这东西其实很好理解,你只要记住:如果一个方法重复执行多次,产生的效果是一样的,那么这个方法就是幂等的。「它本质上意味着成功执行请求的结果与其执行次数无关。」

让我们来具体看看每一项的分析:

  1. GET方法用于获取资源,不应该有副作用,所以它是「幂等」的。例如:GET http://lindaidai.wang/account/123,不会改变资源的状态,不论是调用一次还是N次都没有副作用。但是要注意了,这里指的是「调用多少次都没有副作用」,而不是每次GET的结果都相同。因为你想想有可能直接去改了数据库的这条数据,那么下次获取到的可能就不相同了,但是它本身并没有产生副作用,所以满足幂等。
  2. HEAD方法GET情况一样,只不过它只用于获取报文首部,不返回报文主体,所以它也是「幂等」的。
  3. POST和PUT很容易让人混淆,之前我总是简单的认为:POST表示创建资源,PUT表示更新资源;但是实际上它们都可用于创建和更新资源,只不过本质的差别就在于幂等性上。POST所对应的URI并非创建资源的本身,而是「资源的接收者」。例如:POST http://lindaidai.wang/articles的语义是在http://lindaidai.wang/articles下创建一篇帖子,HTTP响应中应包含帖子的创建状态以及帖子的URI。两次相同的POST请求会在服务器端创建两份资源,它们具有不同的URI,所以POST是「非幂等」的。
  4. PUT方法所对应的URI是要创建或者更新「资源本身」。这点很容易让人误会它不是幂等的,但其实它是「幂等」的。例如:PUT http://lindaidai.wang/accout/321 的语义是创建或者更新ID为123的帖子。第一次PUT方法执行之后,其在服务器上生成的资源,不能被后续的PUT方法更改,所以对同一URI进行多次PUT的副作用和一次PUT是相同的,因而它是「幂等」的。
  5. DELETE方法用于删除资源,有副作用(意思就是会修改服务器上的资源内容),但它却是「幂等」的。因为例如:DELETE http://lindaidai.wang/accout/321调用一次和调用N次对系统产生的副作用是相同的,都是为了删掉ID为321的帖子。因此,调用者可以多次调用或刷新页面而不必担心引起错误。
  6. OPTIONS这个很好理解,只是为了获取服务器支持的方法,我知道的一般是使用了代理然后进行一个预请求的时候会用到。它是「幂等」的。

【面试时答法】

一个方法是不是幂等,其实就是判断一个方法重复执行多次,产生的效果是不是一样的,如果是幂等的话,它本质上意味着成功执行请求的结果和它的执行次数无关。我所知道的,只有「POST」「PATCH」是非幂等的,其它都是幂等操作。

3.3 GET和POST的区别

不用我多说,常问知识点,重要指数:?????

(这里我用的是三元总结的一份答案+自己的一些理解)

  • 从缓存的角度上说,GET会被浏览器主动缓存下来,留下历史记录,但是POST不会。
  • 从编码的角度上说,GET只能进行URL编码,它只能接收ASCII字符,但是POST没有限制。
  • 从参数的角度上说,GET一般放在URL上传递参数,POST放在请求体里,更适合传递敏感信息。
  • 从幂等的角度上说,GET是幂等的,而POST不是。
  • 不过据我了解的,其实GET和POST本质上都是TCP连接,并无差别。但是由于HTTP的规定和浏览器/服务器的限制,导致它们在应用过程中体现出一些不同。
  • 还有可以从TCP的角度上说,GET请求会把请求报文一次性发出去,但是POST会分为两个TCP数据包。首先发送的是header部分,若是服务器响应100(continue),则会发送body部分,当然「火狐」浏览器除外,它的 POST 请求只发一个 TCP 包。

(这时候面试官可能还会追加着问你:既然POST要分为两个TCP数据包发送,那GET是不是会比POST更有效啊)

你可以这样回答:

  • 首先,GET和POST都有它们自己的语义的,最好不要混用
  • 另外,虽然说POST会分为两个数据包发送,但是其实在网络条件好的情况下,发一次包和发两次包的相差的时间基本可以被无视了。并且在网络条件差的情况下,两次包的TCP在验证数据包的完整性上还有更大的优点。
  • 再者,也并不是所有的浏览器的POST请求都会发送两次TCP数据包的,比如火狐就不会。

3.4 支持度

  • OPTIONS、CONNECT、TRACE只在HTTP/1.1以上被支持
  • LINK、UNLINK在HTTP/1.1中被废弃

3.5 服务端收到不支持的方法会如何处理

当服务端收到不支持的方法时,会返回 405 Method Not Allowed,并且会把所有支持的方法写入响应报文首部字段Allow中返回。

4. HTTP状态码

重要指数:?????

(又是个硬核的知识点啊...这里霖呆呆就只列举一些常用的)

1xx 信息性

「请求已经接收到,需要进一步处理才能完成,但是HTTP/1.0 不支持。」

  • 101 Switching Protocols :在HTTP升级为WebSocket时,如果服务器同意变更,则返回 101。

2xx 成功状态

「成功处理请求。」

  • 200 OK :请求成功,通常返回的数据中带有响应体。
  • 204 No Content:意思和200一样,不过返回的数据中不带有响应体。
  • 206 Partial Content:客户端进行了范围请求且服务端正常处理,响应报文的首部应该还有Content-Range字段指定实体的范围。使用场景为HTTP分块下载和断点续传。

3xx 重定向

「重定向状态,资源位置发生变动,需要重新请求。」

  • 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。(可以试一下http://juejin.im)

三种临时重定向简单比较:

  • 302 Found,基本的临时重定向
  • 303 See Other,明确表示客户端应该使用GET方法
  • 307 Temprary Redirect,请求方法和实体都不允许变动

4xx 客户端错误

「客户端出现错误。」

  • 400 Bad Request:请求报文中存在语法错误,但是没有具体指出是哪里。
  • 401 Unauthorized:需要有通过HTTP认证的认证信息或者表示用户认证失败。
  • 403 Forbidden:请求资源被拒绝,原因是:比如法律禁止、信息敏感。
  • 404 Not Found:请求资源未找到,表示没在服务器上找到相应的资源。

5xx 服务端出现错误

「服务端出现错误。」

  • 500 Internal Server Error:服务器内部错误,但是没有具体指出是哪里,和400有点像。
  • 501 Not Implemented:表示客户端请求的功能还不支持
  • 502 Bad GateWay:服务器自身是正常的,但是代理服务器无法获取到合法响应(点外卖时外卖小哥没送)
  • 503 Service Unavailable:服务器内部处于超负载状态或进行停机维护(就像是本店今天不开张)

参数文章

  • 《理解http的幂等性》https://blog.csdn.net/github_36032947/article/details/78421513
  • 《面试官(9):可能是全网最全的http面试答案-寻找海蓝96》
    https://juejin.im/post/5d032b77e51d45777a126183
  • 《「进击的前端工程师」HTTP的世界观(附HTTP/3中文翻译)》
    https://juejin.im/post/5dc6c7a8e51d45160d04a480
  • 《(建议精读)HTTP灵魂之问,巩固你的 HTTP 知识体系-神三元》https://juejin.im/post/5e76bd516fb9a07cce750746
  • 《99%的人都理解错了HTTP中GET与POST的区别-WebTechGarden》
  • 《图解HTTP》

067e2a7fc8d7e678fa257cd3d035f94d.png

其他推荐

React 和 Vue 都在用的 FLIP 思想是什么?

懂这些Javascript的骚操作,你可以更牛B

Javascript重构技巧-让别人看懂你写的代码

Vue3 的诞生的故事

当一个大前端有了服务器时会做些什么?

从零解读Vue3.0源码响应式系统

互联网人相亲现场,该如何battle

7个关于 CSS backgroundImage 好用的技巧

你还用首屏加载时间衡量Web 性能体验和质量?

如何使用Chrome来分析运行时的性能、内存问题 ?[太实用了]

超有料的前端性能优化总结(建议收藏)

一文读懂 babel7 的配置文件加载逻辑

【前端进阶】Nginx 负载均衡和缓存服务实战

CSS高级特效的必备技巧

图文并茂深度解析浏览器渲染原理,包看懂超值得收藏

Vue 的生命周期之间到底做了什么事清?(源码详解)

深度解析文件上传全过程

如何写出被Team Leader喜欢的JS 代码前端面试128问汇总(含超详细答案)你不一定知道的CSS 中的auto可以任意插拔随意组合的业务级前端模块化神器!超详细webpack构建方式补给!超详细webpack基础补给!当你升级到前端的TL时,如何快速打造用于中小团队的前端基建线上项目出现问题时如何快速调试定位问题?学习 React Hooks 可能会遇到的五个灵魂问题你确定你真的懂CSS吗?太齐了!前端的学习及工作资料只收藏这份就够了!大厂都在用的高级缓存方案我这个页面居然用了10G的GPU?!!微前端在企业级应用中的实践(华为项目经验传授)原来微信支付软件架构是这样哒!!!有这个!你还愁不会写正则吗?看我如何把node接口耗时降低23%!高级前端工程师是怎样高效部署前端应用?【撩妹教程】如何教公司新来的女实习生小姐姐什么是闭包?前端如何在繁忙的业务中提升自己全链路日志如何实现?大厂的高性能小程序原来是这样弄的!测试一下你离前端专家这个称号还有多远?

7e2833fb961beb861c10cb86b68b4050.png

dd1769441219377ef960760eb6a99764.png点在看的人特别帅/美3088c6a8681eaffe590b5d4b7dc68849.gif



推荐阅读
  • Linux一键安装web环境全攻略
    摘自阿里云服务器官网,此处一键安装包下载:点此下载安装须知1、此安装包可在阿里云所有Linux系统上部署安装,此安装包包含的软件及版本为& ... [详细]
  • 这是原文链接:sendingformdata许多情况下,我们使用表单发送数据到服务器。服务器处理数据并返回响应给用户。这看起来很简单,但是 ... [详细]
  • Nginx使用AWStats日志分析的步骤及注意事项
    本文介绍了在Centos7操作系统上使用Nginx和AWStats进行日志分析的步骤和注意事项。通过AWStats可以统计网站的访问量、IP地址、操作系统、浏览器等信息,并提供精确到每月、每日、每小时的数据。在部署AWStats之前需要确认服务器上已经安装了Perl环境,并进行DNS解析。 ... [详细]
  • GetWindowLong函数
    今天在看一个代码里头写了GetWindowLong(hwnd,0),我当时就有点费解,靠,上网搜索函数原型说明,死活找不到第 ... [详细]
  • 本文介绍了使用AJAX的POST请求实现数据修改功能的方法。通过ajax-post技术,可以实现在输入某个id后,通过ajax技术调用post.jsp修改具有该id记录的姓名的值。文章还提到了AJAX的概念和作用,以及使用async参数和open()方法的注意事项。同时强调了不推荐使用async=false的情况,并解释了JavaScript等待服务器响应的机制。 ... [详细]
  • 知识图谱——机器大脑中的知识库
    本文介绍了知识图谱在机器大脑中的应用,以及搜索引擎在知识图谱方面的发展。以谷歌知识图谱为例,说明了知识图谱的智能化特点。通过搜索引擎用户可以获取更加智能化的答案,如搜索关键词"Marie Curie",会得到居里夫人的详细信息以及与之相关的历史人物。知识图谱的出现引起了搜索引擎行业的变革,不仅美国的微软必应,中国的百度、搜狗等搜索引擎公司也纷纷推出了自己的知识图谱。 ... [详细]
  • http:my.oschina.netleejun2005blog136820刚看到群里又有同学在说HTTP协议下的Get请求参数长度是有大小限制的,最大不能超过XX ... [详细]
  • 本文介绍了Web学习历程记录中关于Tomcat的基本概念和配置。首先解释了Web静态Web资源和动态Web资源的概念,以及C/S架构和B/S架构的区别。然后介绍了常见的Web服务器,包括Weblogic、WebSphere和Tomcat。接着详细讲解了Tomcat的虚拟主机、web应用和虚拟路径映射的概念和配置过程。最后简要介绍了http协议的作用。本文内容详实,适合初学者了解Tomcat的基础知识。 ... [详细]
  • 本文介绍了在Windows环境下如何配置php+apache环境,包括下载php7和apache2.4、安装vc2015运行时环境、启动php7和apache2.4等步骤。希望对需要搭建php7环境的读者有一定的参考价值。摘要长度为169字。 ... [详细]
  • iOS超签签名服务器搭建及其优劣势
    本文介绍了搭建iOS超签签名服务器的原因和优势,包括不掉签、用户可以直接安装不需要信任、体验好等。同时也提到了超签的劣势,即一个证书只能安装100个,成本较高。文章还详细介绍了超签的实现原理,包括用户请求服务器安装mobileconfig文件、服务器调用苹果接口添加udid等步骤。最后,还提到了生成mobileconfig文件和导出AppleWorldwideDeveloperRelationsCertificationAuthority证书的方法。 ... [详细]
  • POCOCLibraies属于功能广泛、轻量级别的开源框架库,它拥有媲美Boost库的功能以及较小的体积广泛应用在物联网平台、工业自动化等领域。POCOCLibrai ... [详细]
  • 现在比较流行使用静态网站生成器来搭建网站,博客产品着陆页微信转发页面等。但每次都需要对服务器进行配置,也是一个重复但繁琐的工作。使用DockerWeb,只需5分钟就能搭建一个基于D ... [详细]
  • 如何搭建服务器环境php(2023年最新解答)
    导读:本篇文章编程笔记来给大家介绍有关如何搭建服务器环境php的相关内容,希望对大家有所帮助,一起来看看吧。本文目录一览:1、怎么搭建p ... [详细]
  •  项目地址https:github.comffmydreamWiCar界面做的很难看,美工方面实在不在行。重点是按钮触摸事件的处理,这里搬了RepeatListener项目代码,例 ... [详细]
  • centos php部署到nginx 404_NodeJS项目部署到阿里云ECS服务器全程详解
    本文转载自:http:www.kovli.com20170919ecs-deploy作者:Kovli本文详细介绍如何部署NodeJS项目到阿里云ECS上, ... [详细]
author-avatar
mobiledu2502875617
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有