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

该内容主要整理关于 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 响应状态码

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

docker-compose Install HertzBeat

HertzBeat前言 HertzBeat 赫兹跳动 是一个拥有强大自定义监控能力,高性能集群,兼容 Prometheus,无需 Agent 的开源实时监控告警系统。 易用友好的开源实时监控告警系统,无需Agent,高性能集群,兼容Prometheus,强大自定义监控能力。​ 集 监控+告警+通知 为一体,支持对…

ToF传感器在移动机器人中的作用

原创 | 文 BFT机器人 在日新月异的机器人技术领域,技术的无缝整合正引领着人类与机器交互方式的革新潮流。ToF传感器作为变革性创新的一个例子,对移动机器人更好地感知周围环境起到了决定性的作用。 ToF传感器与激光雷达技术在创建深度图方面有着异曲同…

SpringBoot实战2

目录 1.如何返回两个类型的数据?User和Booth 2.如何使用MyBatis遍历一个数组进行查询? 3.前端要的数据太多太杂,我们拼接多个List,前端找数据困难,浪费时间。因此我们进行三表联表查询。 1.首先创建一个vo包&#x…

c++ STL less 的视角

c less 函数在不同的地方感觉所起的作用是不一样的, 这中间原因是 less 的视角不一样, 下面尝试给出解释下, 方便记忆 1、 左右视角 符合 排序sort less(value, element) less 表示一种 “符合关系“, 表示sort 后…

大数据环境搭建(一)-Hive

1 hive介绍 由Facebook开源的,用于解决海量结构化日志的数据统计的项目 本质上是将HQL转化为MapReduce、Tez、Spark等程序 Hive表的数据是HDFS上的目录和文件 Hive元数据 metastore,包含Hive表的数据库、表名、列、分区、表类型、表所在目录等。 根据Hive部署模…

蓝桥杯第九届省赛题-----彩灯控制系统笔记

题目要求: 一、 基本要求 1.1 使用 CT107D 单片机竞赛板,完成“彩灯控制器”功能的程序设计与调 试; 1.2 设计与调试过程中,可参考组委会提供的“资源数据包”; 1.3 Keil 工程文件以准考证号命名&#xff0c…

在VM虚拟机搭建NFS服务器

NFS共享要求如下: (1)共享“/mnt/自已姓名的完整汉语拼音”目录,允许XXX网段的计算机访问该共享目录,可进行读写操作。(说明:XXX网段,请根据你的规划,再具体指定&#xf…

VUE开发记录

1、VUE模板传递参数到JS方法 <select-language :value"item.language" change"selectLanguage($event, key)"></select-language>selectLanguage(value, key){console.log(value, key) }, 2、Element框架el-form-item自定义label和内容 <…

远秋医学培训系统未授权查看密码

指纹特征 title"远秋医学培训报名系统v1.0"漏洞复现 POC&#xff1a;/User/ManagerList.aspx?ty1&ty1

好的问卷设计标准:确保数据质量与准确性的关键要素

问卷的主要由三个部分组成&#xff1a;问卷说明、问卷主题、问卷结束。而这三个部分又包含了很多因素&#xff0c;比如问卷主题、问卷标题、问卷题目、问卷调查对象等。制作问卷不仅仅是简单的问题罗列&#xff0c;然后进行发放。不同质量的调查问卷会反馈出不一样的效果&#…

高级变量赋值和变量的间接引用

1.高级变量赋值 var${str-lucky} 变量配置方式 var${str:-lucky} 变量配置方式 var${strlucky} 变量配置方式 2.变量的间接引用 eval 命令 eval命令将会首先扫描命令行进行所有的置换&#xff0c;然后再执行该命令。该命令适用于那些一次扫描无法实现其功能的变量,该命令对变…

MySQL学习记录——일 MySQL 安装、配置

文章目录 1、卸载内置环境2、安装MySQL3、启动4、登录5、配置my.cnf 当前环境是1核2G云服务器&#xff0c;CentOS7.6。要在root用户下进行操作 1、卸载内置环境 云服务器中有可能会自带mysql还有mariadb这样的数据库服务&#xff0c;在安装我们mysql前&#xff0c;得先查找一下…

Java学习六、数组的定义与使用

一、数组的创建及初始化 数组是相同类型元素的集合&#xff0c;在内存中是一段连续的空间。 1.数组的创建 T[] 数组名 new T[N]; T&#xff1a;表示数组中存放元素的类型 N:表示数组长度 int[] array1 new int[10];//创建一个可以容纳10个int类型元素的数组 double[] array…

BeanDefinitionRegistry学习

Spring版本5.1.x 简介 在Spring框架中&#xff0c;BeanDefinitionRegistry是一个接口&#xff0c;它主要用于向注册表中注册BeanDefinition实例&#xff0c;完成注册的过程。该接口的主要方法是registerBeanDefinition&#xff0c;用于将一个BeanDefinition实例注册到注册表中…

2023年09月CCF-GESP编程能力等级认证Python编程一级真题解析

Python等级认证GESP(1~6级)全部真题・点这里 一、单选题(共15题,共30分) 第1题 我们通常说的“内存”属于计算机中的 ( )。 A:输出设备 B:输入设备 C:存储设备 D:打印设备 答案:C 第2题 以下Python不可以作为变量的名称的是 ( )。 A:redStar B:RedStar C:red…

在RunnerGo测试平台中做WebSocket、Dubbo、TCP/IP接口测试

大家好&#xff0c;RunnerGo作为一款一站式测试平台不断为用户提供更好的使用体验&#xff0c;最近得知RunnerGo新增对&#xff0c;WebSocket、Dubbo、TCP/IP&#xff0c;三种协议API的测试支持&#xff0c;本篇文章跟大家分享一下使用方法。 WebSocket协议 WebSocket 是一种…

前端面试拼图-数据结构与算法

摘要&#xff1a;总结一些前端算法题&#xff0c;持续更新&#xff01; 一、数据结构与算法 时间复杂度-程序执行时需要的计算量&#xff08;CPU&#xff09; 空间复杂度-程序执行时需要的内存空间 前端开发&#xff1a;重时间&#xff0c;轻空间 1.把一个数组旋转k步 arr…

UnityShader(十四)纹理

目录 前言&#xff1a; 单张纹理实现效果&#xff1a; 效果&#xff1a; 前言&#xff1a; 纹理最初的目的是用一张图片来控制模型的外观。使用纹理映射技术我们可以把一张图“贴”在模型表面&#xff0c;逐纹素&#xff08;文素的名字是为了和像素进行区分&#xff09;控制…

开源软件:引领技术创新、商业模式与安全的融合

序 在信息技术日新月异的今天&#xff0c;开源软件以其独特的魅力和影响力&#xff0c;正逐渐成为软件产业的新常态。开源软件的低成本、高度可协作性和透明度等特点&#xff0c;不仅吸引了无数企业和个人用户的青睐&#xff0c;更为软件行业带来了前所未有的繁荣景象。 一、…

代码随想录算法训练营DAY11 | 栈与队列 (2)

一、LeetCode 20 有效的括号 题目链接&#xff1a;20.有效的括号https://leetcode.cn/problems/valid-parentheses/ 思路&#xff1a;遇到左括号直接进栈&#xff1b;遇到右括号判断站顶是否有匹配的括号&#xff0c;没有就返回flase&#xff0c;有就将栈顶元素出栈&#xff1…