【面试八股总结】超文本传输协议HTTP(一)

参考资料 :小林Coding、阿秀、代码随想录 

一、 什么是HTTP协议?

HTTP是超文本传输协议 HyperText Transfer Protocol

特性:

  • 简单、灵活、易于扩展
  • 无状态:服务器不会记忆HTTP状态
  • 不安全通信使用明文,不验证通信方身份,无法的证明报文的完整性(可能被篡改)

二、 HTTP报文

1. HTTP请求报文

  • Request Line         请求行:请求方法 URL  HTTP协议版本号
  • Request  Headers 请求头:包含请求的附加信息,由key:value组成
  •                               空    行:分隔请求头和请求体
  • Request Body        请求体:承载多个请求参数的数据(可选)

2. HTTP响应报文

  • Status Line              状态⾏:HTTP协议版本 状态码 状态消息
  • Response Headers 响应头:以键值对的形式提供的额外信息
  •                                 空    行
  • Response Body       响应体:体包含服务器返回给客户端的实际数据

三、 HTTP请求方法

HTTP1.0 定义了三种请求⽅法: GET, POST 和 HEAD⽅法。

HTTP1.1 新增了六种请求⽅法:OPTIONS、PUT、PATCH、DELETE、TRACE 和 CONNECT ⽅法

方法描述
GET请求指定的⻚⾯信息,并返回实体主体。
POST

向指定资源提交数据进行处理请求(eg.提交表单/上传文件),数据包含在请求体中。

POST请求可能导致新的资源建立/已有资源的改变。

HEAD类似于GET,但返回相应中没有具体资源,用于获取情报头。
PUT从客户端向服务器传送的数据取代指定的文档的内容。
DELETE请求服务器删除指定页面。
CONNECTHTTP1.1 协议中预留给能够将连接改为管道方式的代理服务器,用于代理服务器。
OPTIONS允许客户端查看服务器的性能。
TRACE回显服务器收到的请求,主要用于测试或诊断。
PATCH对PUT方法的补充,用于对已知资源进行局部更新。

 GET和POST有什么区别?

GETPOST
概念获取数据,不影响服务器修改数据,会影响服务器
参数传递GET请求参数一般写在URL中,所以GET传送的数据量一般较小,不能大于2K,且只接受ASCII字符。POST请求参数一般放在请求体中,其请求信息没有长度限制和数据类型限制。
请求报文GET将请求的数据放在URL上,以?分割URL和传输数据,参数以&相连POST将数据放在HTTP的请求体内
安全

安全,因为GET为只读操作,不会对服务器数据产生影响。

不安全,POST方法会修改服务器上资源。
幂等幂等,每次GET都不会改变服务器资源。不幂等,多次提交数据会创建多个资源。
缓存机制

GET请求会被浏览器主动缓存,请求参数也被完整保留在浏览器历史记录中,且在浏览器中 GET 请求可以保存为书签。

POST不会被浏览器主动缓存,参数也不会被保留,也不能把POST请求作为书签。

时间消耗GET产生一个TCP数据包:浏览器会把Header和Data一并发送出去,服务器相应200(返回数据)POST产生两个TCP数据包:浏览器先发送Header,服务器响应100 continue,浏览器再发送Data,服务器响应200 ok(返回数据)
编码方式只能进行URL编码支持多种编码方式

补充说明:

 1)HTTP协议没有Body和URL的长度限制,对URL限制的大多是浏览器和服务器的原因。

 2)安全:HTTP协议中,安全是指请求方法不会破坏服务器上的资源。

 3)幂等:多次执行相同的操作,结果都相同。一次和多次请求某一个资源应该具有相同的作用,

四、 HTTP状态码

状态码分类具体🌰含义
1xx 信息100 Continue表明到⽬前为⽌都很正常,客户端可以继续发送请求或者忽略这个响应。
2xx 成功200 OK最常见的成功状态码,表示一切正常。如果是非 HEAD请求,服务器返回的响应头都会有 body 数据。
204 No Content请求已经成功处理,但是返回的响应报⽂不包含实体的主体部分。⼀般在只需要从客户端 往服务器发送信息,⽽不需要返回数据时使⽤。
206 Partial Content表示客户端进⾏了范围请求,响应报⽂包含由 Content-Range 指定范围的实体内 容。
3xx 重定向301 Moved Permanently 永久性重定向,说明请求的资源已经不存在了,需改用新的 URL 再次访问。
302 Found临时性重定向
303 See Other和 302 有着相同的功能,但是 303 明确要求客户端应该采⽤ GET ⽅法获取资源。
304 Not Modified如果请求报⽂⾸部包含⼀些条件,例如:If-Match,If-Modified-Since,If-None-Match,If-Range,If-Unmodified-Since,如果不满⾜条件,则服务器会返回 304 状态码。
307 Temporary Redirect临时重定向,与 302 的含义类似,但是 307 要求浏览器不会把重定向请求的 POST ⽅法改成 GET ⽅法。
4xx 客户端错误400 Bad Request请求报⽂中存在语法错误。
401 Unauthorized该状态码表示发送的请求需要有认证信息(BASIC 认证、DIGEST 认证)。如果之前已 进⾏过⼀次请求,则表示⽤户认证失败。
403 Forbidden请求被拒绝。
404 Not Found请求的资源在服务器上不存在或未找到,所以无法提供给客户端。
5xx 服务器错误500 Internal Server Error服务器正在执⾏请求时发⽣错误。
501 Not Implemented客户端请求的功能还不支持。
502 Bad Gateway服务器作为网关或代理时返回的错误码,表示服务器自身工作正常,访问后端服务器发生了错误。
503 Service Unavailable服务器暂时处于超负载或正在进⾏停机维护,现在⽆法处理请求。

五、 HTTP常见字段

分类字段名称含义
通⽤头部字段General HeadersCache-Control指定缓存策略
Connection控制连接的⾏为
Date指定⽇期和时间
请求头部字段Request HeadersAccept指定客户端能够接受的响应的MIME类型
Accept-Encoding指定客户端⽀持的内容编码⽅式
Authorization⽤于进⾏身份验证的凭据
Host指定请求的⽬标主机和端⼝
User-Agent标识客户端的⽤户代理(浏览器或其他⼯具)

响应头部字段

Response Headers

Content-Length 服务器返回数据时,带有该字段,表示回应的数据长度
Content-Type服务器回应时,告诉客户端本次数据的格式
Content-Enconding服务器返回的数据使用了什么压缩格式

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/588394.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

孙崧-回归祖国的数学天才谈国外学习研究感受

孙崧,这位37岁的美国加州大学伯克利分校数学系教授,今年正式回归祖国,担任浙江大学数学高等研究院杜建英讲席教授、博士生导师。在此,知识人网小编就经历过国外就读、从事博士后研究及任教的这位数学天才是怎么说的,或…

基于java+springboot+vue实现的仓库管理系统(文末源码+Lw)23-115

摘 要 使用旧方法对仓库管理系统的信息进行系统化管理已经不再让人们信赖了,把现在的网络信息技术运用在仓库管理系统的管理上面可以解决许多信息管理上面的难题,比如处理数据时间很长,数据存在错误不能及时纠正等问题。这次开发的仓库管理…

第27篇:T触发器实现4位计数器

Q:本篇我们用T触发器实现时序逻辑电路--计数器。 A:T触发器(Toggle Flip-Flop)只有一个信号输入端,在时钟有效边沿到来时,输入有效信号则触发器翻转,否则触发器保持不变,因此T触发器…

【Entity Framework】EF日志-简单日志记录

【Entity Framework】EF日志-简单日志记录 文章目录 【Entity Framework】EF日志-简单日志记录一、概述二、EF日志分类三、简单的日志记录3.1 配置3.2 日志记录到控制台3.3 记录到凋试窗口3.4 记录到文件3.5 敏感数据处理3.6 详细查询异常3.6 日志级别3.7 消息内容和格式设置 一…

路由和远程访问是什么?

路由和远程访问在现代互联网时代中,扮演着至关重要的角色。它们为我们提供了便捷的信息传递途径,让不同地区的电脑、设备以及人们之间能够轻松进行通信和交流。 对于路由来说,它是连接互联网上的各个网络的核心设备。一台路由器可以将来自不同…

浏览器工作原理与实践--WebAPI:XMLHttpRequest是怎么实现的

在上一篇文章中我们介绍了setTimeout是如何结合渲染进程的循环系统工作的,那本篇文章我们就继续介绍另外一种类型的WebAPI——XMLHttpRequest。 自从网页中引入了JavaScript,我们就可以操作DOM树中任意一个节点,例如隐藏/显示节点、改变颜色、…

参数传值机制

在 Java 中,方法的所有参数都是 “传值” 的 基本类型:数值的拷贝 引用类型:引用的拷贝 方法内部改变参数对象的状态(修改某属性),改变将反映到原始对象上 因为方法内部和外部引用的是同一个对象 方法内部…

git源码泄露

Git 源码泄露 开发人员会使用 git 进行版本控制,对站点自动部署。但如果配置不当,可能会将 .git 文件夹直接部署到线上环境,这就引起了 git 泄露漏洞,我们可以利用这个漏洞直接获得网页源码。 确定是否存在泄漏 (1&…

LabVIEW专栏二、调用子VI

该节目标是创建带子vi,修改vi属性,测试可重入和不可重入的区别 一 、设置子VI 把VI封装成为子VI,可以帮助模块化程序,简化代码结构。 任何VI本身都可以成为别的VI的子VI。 1.1、设置输入输出端子 1、在前面板空白处&#xff0…

idea快速找到maven中冲突的依赖,解决依赖冲突

红色实线:冲突,红色虚线:依赖于同一个包的多版本 选择包,右键Excluede,排除 问题原因: 一个项目中需要jar包A和jar包B,而jar包A和jar包B都需要依赖jar包C,但A需要1.2.16版本的C,B需要1.2.17版本的C,这时候就可能会产…

教育信创 | 云轴科技ZStack联合飞腾发布全场景教育信创白皮书

随着数字化时代的到来,教育行业正面临着前所未有的挑战与机遇。为了推动教育行业的数字化转型和信创人才培养,云轴科技ZStack联合飞腾于3月28日正式发布了《教育行业数字化自主创新飞腾生态解决方案白皮书》(简称《教育白皮书》)。…

SpringBoot+thymeleaf完成视频记忆播放功能

一、背景 1)客户要做一个视频播放功能,要求是系统能够记录观看人员在看视频时能够记录看到了哪个位置,在下次观看视频的时候能够从该位置进行播放。 2)同时,也要能够记录是谁看了视频,看了百分之多少。 说明:由于时间关系和篇幅原因,我们这里只先讨论第一个要求,第…