2024 高级前端面试题之 HTTP模块 「精选篇」

news2025/2/2 20:41:31

该内容主要整理关于 HTTP模块 的相关面试题,其他内容面试题请移步至 「最新最全的前端面试题集锦」 查看。

HTTP模块精选篇

  • 1. HTTP 报文的组成部分
  • 2. 常见状态码
  • 3. 从输入URL到呈现页面过程
      • 3.1 简洁
      • 3.2 详细
  • 4. TCP、UDP相关
  • 5. HTTP2相关
  • 6. https相关
  • 7. WebSocket的实现和应用
  • 8. Token、cookie、Session区别
  • 9. 一个图片 url 访问后直接下载怎样实现
  • 10. fetch 发送 2 次请求的原因
  • 11. GET 和 POST 的区别
  • 12. 301 和 302 的区别
  • 13. DNS的作用、DNS解析的详细过程,DNS优化原理
  • 14. 简单请求和复杂请求
  • 15. Http请求中的keep-alive有了解吗
  • 16. 管道机制的作用是什么
  • 17. 什么情况下会触发 option 请求
  • 18. GET 可以上传图片吗
  • 19. CDN 的作用和原理
  • 20. 强缓存命中发生了什么?
  • 21. CORS跨域的原理
  • 22. 在深圳的网页上输入百度,是怎么把这个请求发到北京的
  • 23. 为什么使用多域名部署?
  • 24. 页面10张img,http1是怎样的加载表现?怎样解决的?
  • 25. 说一说SSO单点登录
  • 26. 说一说OAuth
  • 27. HTTP 中的 301、302、303、307、308 响应状态码


1. HTTP 报文的组成部分

请求报文

  • 请求行 ( http 方法 + 页面地址 + http 协议 + 版本)
  • 请求头( key + value 值)
  • 空行(服务端通过空行来判断下一部分不再是请求头,而当做请求体来解析)
  • 请求体(数据部分)

响应报文

  • 状态行 + 响应头 + 空行 + 响应体

2. 常见状态码

状态码分类

  • 1xx:服务器收到请求
  • 2xx:请求成功,如 200
  • 3xx:重定向,如 302
  • 4xx:客户端错误,如 404
  • 5xx:服务端错误,如 500

常见状态码

  • 200:成功
  • 301:永久重定向(配合 location,浏览器自动处理)
  • 302:临时重定向(配合 location,浏览器自动处理)
  • 304:资源未被修改
  • 400: 请求语法错误
  • 401: 未授权
  • 403:没权限
  • 404:资源未找到
  • 500:服务器错误
  • 504:网关超时

HTTP状态码
[待上传]

3. 从输入URL到呈现页面过程

3.1 简洁

  • 浏览器的地址栏输入URL并按下回车;
  • DNS 解析:将域名解析成 IP 地址;
  • TCP 连接:TCP 三次握手;(三次握手的目的:为了防止已经失效的连接 请求报文段突然又传送到了服务器端,从而产生错误)
  • 发送 HTTP 请求;
  • 服务器处理请求并返回 HTTP 报文;
  • 浏览器解析渲染页面;
  • 断开连接:TCP 四次挥手

3.2 详细

HTTP请求示意图
在这里插入图片描述

浏览器中的HTTP请求从发起到结束一共经历了如下八个阶段:构建请求、查找缓存、准备IP和端口、等待TCP队列、建立TCP连接、发起HTTP请求、服务器处理请求、服务器返回请求和断开连接

  • 用户输入url并回车

  • 浏览器进程检查url,组装协议,构成完整的url

  • 浏览器进程通过进程间通信(IPC)把url请求发送给网络进程

  • 网络进程接收到url请求后检查本地缓存是否缓存了该请求资源,如果有则将该资源返回给浏览器进程

  • 如果没有,网络进程向web服务器发起http请求(网络请求),请求流程如下:

    • 进行DNS解析,获取服务器ip地址,端口
    • 利用ip地址和服务器建立tcp连接
    • 构建请求头信息
    • 发送请求头信息服务器响应后,网络进程接收响应头和响应信息,并解析响应内容
  • 网络进程解析响应流程:

    • 检查状态码,如果是301/302,则需要重定向,从 Location 自动中读取地址,重新进行第4步,如果是200,则继续处理请求
    • 200响应处理:检查响应类型Content-Type,如果是字节流类型,则将该请求提交给下载管理器,该导航流程结束,不再进行后续的渲染,如果是html则通知浏览器进程准备渲染进程准备进行渲染
  • 准备渲染进程

    • 浏览器进程检查当前url是否和之前打开的渲染进程根域名是否相同,如果相同,则复用原来的进程,如果不同,则开启新的渲染进程
  • 传输数据、更新状态

    • 渲染进程准备好后,浏览器向渲染进程发起“提交文档”的消息,渲染进程接收到消息和网络进程建立传输数据的“管道”
    • 渲染进程接收完数据后,向浏览器发送“确认提交”
    • 浏览器进程接收到确认消息后更新浏览器界面状态:安全、地址栏url、前进后退的历史状态、更新web页面

4. TCP、UDP相关

  • 4.1 UDP 和 TCP 有什么区别
  • 4.2 TCP 为什么要三次握手
  • 4.3 三次握手过程中可以携带数据吗
  • 4.4 TCP 的四次挥手
  • 4.5 TCP 和 UDP 的区别
  • 4.6 HTTP 和 TCP 的不同

5. HTTP2相关

  • 5.1 说一下 http2.0
  • 5.2 HTTP2 和 HTTP1 有什么区别
  • 5.3 http/2 为什么要做头部压缩,实现原理是什么?
  • 5.4 http/2 的 Server Push 有什么优点
  • 5.5 谈谈你对多路复用的理解

6. https相关

  • 6.1 HTTPS 加的一层 SSL 在七层中哪个位置
  • 6.2 https 协议的优点
  • 6.3 https 协议的缺点
  • 6.4 http 与 https 区别
  • 6.5 https 传输的具体过程
  • 6.6 HTTPS 的整体过程分为证书验证和数据传输阶段
  • 6.7 介绍一下 https 的握手过程
  • 6.8 为什么 https 数据传输使用对称加密
  • 6.9 介绍下 https 中间人攻击的过程
  • 6.10 HTTPS 握手过程中,客户端如何验证证书的合法性
  • 6.11 问题
  • 6.12 数字签名?它是什么
  • 6.13 谈谈对数字证书的理解
  • 6.14 为什么说数字证书就能对通信方的身份进行验证呢
  • 6.15 请详细的说一下 HTTPS 它的加密传输过程,涉及到哪些算法呢?
  • 6.16 描述一下 RSA 握手
  • 6.17 ECDHE 握手和 RSA 握手又有什么区别呢
  • 6.18 你知道 TSL1.3 版本吗?它较 TSL1.2 做了哪些改进呢?
  • 6.19 介绍下 HTTPS 中间人攻击
  • 6.20 http/https 协议总结

7. WebSocket的实现和应用

  • 7.1 什么是 WebSocket
  • 7.2 WebSocket 是什么样的协议,具体有什么优点
  • 7.3 理解WebSocket协议的底层原理、与HTTP的区别

8. Token、cookie、Session区别

  • 8.1 Cookie 和 session 的区别
  • 8.2 cookie 和 token 都存放在 header 中,为什么不会劫持 token?
  • 8.3 介绍下如何实现 token 加密

9. 一个图片 url 访问后直接下载怎样实现

10. fetch 发送 2 次请求的原因

11. GET 和 POST 的区别

12. 301 和 302 的区别

13. DNS的作用、DNS解析的详细过程,DNS优化原理

14. 简单请求和复杂请求

15. Http请求中的keep-alive有了解吗

16. 管道机制的作用是什么

17. 什么情况下会触发 option 请求

18. GET 可以上传图片吗

19. CDN 的作用和原理

  • 如何捕获 CDN 上的 js 运行时导致的详细错误信息?

20. 强缓存命中发生了什么?

  • 默认的强制缓存时间是多少?

21. CORS跨域的原理

  • CORS的哪些是简单请求?
  • CORS的预检请求具体是怎样的?
  • 为什么简单请求不需要预检?
  • 复杂请求预检检查什么东西?
  • 如果CORS附带身份凭证要怎样做?
  • 如何减少CORS预请求的次数?

22. 在深圳的网页上输入百度,是怎么把这个请求发到北京的

23. 为什么使用多域名部署?

24. 页面10张img,http1是怎样的加载表现?怎样解决的?

25. 说一说SSO单点登录

26. 说一说OAuth

27. HTTP 中的 301、302、303、307、308 响应状态码

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

数据库建模之PowerDesigner创建概念模型

数据模型(Data Model)是数据特征的抽象,它从抽象层次上描述了系统的静态特征、动态行为和约束条件,为数据库系统的信息表示与操作提供一个抽象的框架。数据模型所描述的内容有三部分,分别是数据结构、数据操作和数据约…

Qwen-VL 技术报告总结

感谢如此优秀的开源工作,仓库链接 Qwen-VL 权重分为 Qwen-VL && Qwen-VL-Chat,区别文档稍后介绍 训练过程 在第一阶段中主要使用224X224分辨率训练,训练数据主要来源是公开数据集,经过清洗,数据总量大约是1.4B,中文数据和英文j训练目标是视觉语言和文本语言对齐。…

【MySQL】——用SQL语句实现数据库和基本表的创建

🎃个人专栏: 🐬 算法设计与分析:算法设计与分析_IT闫的博客-CSDN博客 🐳Java基础:Java基础_IT闫的博客-CSDN博客 🐋c语言:c语言_IT闫的博客-CSDN博客 🐟MySQL&#xff1a…

Windows Server 2019 Web服务器搭建

系列文章目录 提示:这里可以添加系列文章的所有文章的目录,目录需要自己手动添加 例如:第一章 Python 机器学习入门之pandas的使用 提示:写完文章后,目录可以自动生成,如何生成可参考右边的帮助文档 文章目…

【Java】实现图书管理系统

文章目录 1. 设计背景2. 需求分析3. 设计思路4. 实现4.1 book包4.1.1 Book类4.1.2 BookList类(书架) 4.2 user包4.2.1 User 类4.2.2 AdminUser类(管理员用户)4.2.3 NormalUser类(普通用户) 4.3 operation包4.3.1 IOPeration接口4.…

产学研交流 | 广东轻工职业技术学院莅临调研

产学研融合是当前教育发展的重要趋势,通过学校与企业之间的深度合作,提高学生的实践能力和创新精神,同时促进企业的技术进步和产业升级。 近日,广东轻工职业技术学院杨军主任、骨干教师丁向荣莅临科东软件,双方就“产学…

spring-security 默认登录页面

Spring Security是一个强大且高度可定制的身份验证和访问控制框架。天然与Spring整合,易扩展,引入jar包就可以用了,在boot自动装载下,不需要任何配置就可以控制资源访问。那么默认登录页是如何产生的呢? 版本信息 内…

使用 git 将本地文件上传到 gitee 远程仓库中,推送失败

项目场景: 背景: 使用 git 想要push 本地文件 到 另一个远程仓库,执行 git push origin master后此时报错 问题描述 问题: git push 本地文件 到 另一个远程仓库时,运行 git push origin master ,push文件失败&…

k8s之基础组件说明

前言 K8S,全称 Kubernetes,是一个用于管理容器的开源平台。它可以让用户更加方便地部署、扩展和管理容器化应用程序,并通过自动化的方式实现负载均衡、服务发现和自动弹性伸缩等功能。 具体来说,Kubernetes 可以将应用程序打包成…

异构计算关键技术之多线程技术(三)

异构计算关键技术之多线程技术(三) 一、多线程概述 1. 多线程的概念与优劣 多线程是指在程序中同时运行多个线程,每个线程都可以独立执行不同的代码段,且各个线程之间共享程序的数据空间和资源。 优劣: 优点&#…

Leetcode29-最大频率元素计数(3005)

1、题目 给你一个由 正整数 组成的数组 nums 。 返回数组 nums 中所有具有 最大 频率的元素的 总频率 。 元素的 频率 是指该元素在数组中出现的次数。 示例 1: 输入:nums [1,2,2,3,1,4] 输出:4 解释:元素 1 和 2 的频率为 …

模板讲解之进阶

在之前的C入门的博客中我们就学习到了模板初阶,今天我们来学习模板的进阶,以便于更好地将模板运用到代码中 非类型模板参数 模板参数分类类型形参与非类型形参。 类型形参即:出现在模板参数列表中,跟在class或者typename之类的…

使用Docker部署DashDot服务器仪表盘并结合cpolar实现公网监测服务器

最近,我发现了一个超级强大的人工智能学习网站。它以通俗易懂的方式呈现复杂的概念,而且内容风趣幽默。我觉得它对大家可能会有所帮助,所以我在此分享。点击这里跳转到网站。 文章目录 1. 本地环境检查1.1 安装docker1.2 下载Dashdot镜像 2.…

氟化硼二吡咯甲基四嗪,BDP-FL-methyltetrazine,能够提高检测的灵敏度和特异性

BDP FL methyltetrazine,氟化硼二吡咯甲基四嗪,BDP-FL-methyltetrazine,能够提高检测的灵敏度和特异性 您好,欢迎来到新研之家 文章关键词:BDP FL methyltetrazine,氟化硼二吡咯甲基四嗪,BDP-…

Golang 并发控制方式有哪些

Go语言中的goroutine是一种轻量级的线程,其优点在于占用资源少、切换成本低,能够高效地实现并发操作。但如何对这些并发的goroutine进行控制呢? 一提到并发控制,大家最先想到到的是锁。Go中同样提供了锁的相关机制,包…

Android.bp入门指南之浅析Android.bp文件

文章目录 Android.bp文件是什么?Android.bp的主要作用模块定义依赖关系构建规则模块属性插件支持模块的可配置性 为什么会引入Android.bp语法例子 Android.bp文件是什么? Android.bp 文件是 Android 构建系统(Android Build System&#xff…

第1章 简单使用 Linux

第1章 简单使用 Linux 1.1 Linux 的组成 1.2 远程连接 首先以 root 用户登录到 Linux 系统,然后在 Terminal 终端上输入 ip add 命令,来查看 IP 地址。 上图中的 192.168.72.128 就是 IP 地址。 然后打开 XShell 远程连接工具。 然后在命令提示符下输…

2024年美赛数学建模A题思路分析 - 资源可用性和性别比例

# 1 赛题 问题A:资源可用性和性别比例 虽然一些动物物种存在于通常的雄性或雌性性别之外,但大多数物种实质上是雄性或雌性。虽然许多物种在出生时的性别比例为1:1,但其他物种的性别比例并不均匀。这被称为适应性性别比例的变化。…

计算机设计大赛 深度学习 python opencv 火焰检测识别 火灾检测

文章目录 0 前言1 基于YOLO的火焰检测与识别2 课题背景3 卷积神经网络3.1 卷积层3.2 池化层3.3 激活函数:3.4 全连接层3.5 使用tensorflow中keras模块实现卷积神经网络 4 YOLOV54.1 网络架构图4.2 输入端4.3 基准网络4.4 Neck网络4.5 Head输出层 5 数据集准备5.1 数…

EasyX图形库学习(一)

目录 一、easyX图形库基本介绍 1、easyX的原理 2、easyX的安装 3、easyX的颜色(RGB颜色模型) 颜色模型相关函数: 4、easyX的坐标 二、相关函数介绍: 绘图设备相关函数: 图形颜色及样式设置相关函数: 图形绘制相关函数: 文字输出相关…