HTTP 核心知识点整理

news2025/3/26 10:11:52

1. HTTP 基础

  • 定义:HTTP(HyperText Transfer Protocol)是应用层协议,基于 ​请求-响应模型,用于客户端(浏览器)与服务器之间的通信。
  • 特点
    • 无状态:每次请求独立,服务器不保留客户端状态(通过 Cookie/Session 解决)。
    • 明文传输​(HTTP) vs ​加密传输​(HTTPS)。
    • 默认端口:HTTP(80),HTTPS(443)。

2. HTTP 方法(Methods)​

方法描述幂等性安全性
GET获取资源,参数在 URL 中
POST提交数据,可能创建资源或触发操作
PUT更新整个资源
PATCH部分更新资源
DELETE删除资源
HEAD获取响应头,无响应体

幂等性:多次执行结果相同(如 GET、PUT、DELETE)。
安全性:不修改资源(如 GET、HEAD)。


3. HTTP 状态码(Status Codes)​

状态码类别常见状态码及含义
1xx信息性100(继续)
2xx成功200(OK)​, 201(Created)
3xx重定向301(永久重定向)​, ​302(临时重定向)​, 304Not Modified(缓存未修改)
4xx客户端错误400(请求错误)​, ​401(未认证)​, ​403(禁止访问)​, ​404(未找到)​
5xx服务器错误500(内部错误)​, 502(网关错误), 503(服务不可用)

关键区别

  • 301 vs 302:301 是永久重定向(浏览器缓存),302 是临时重定向。
  • 401 vs 403:401 表示未认证,403 表示无权限。

4. HTTP 头部(Headers)​

  • 通用头部
    • Cache-Control:缓存策略(如 max-age=3600)。
    • Connection:控制连接(如 keep-alive)。
  • 请求头部
    • Host:目标域名。
    • User-Agent:客户端信息。
    • Authorization:认证信息(如 Bearer Token)。
  • 响应头部
    • Content-Type:响应体类型(如 application/json)。
    • Content-Length
    • Content-Encoding
    • Set-Cookie:设置 Cookie。
  • 缓存相关
    • ETag:资源标识,用于协商缓存。
    • Last-Modified:资源最后修改时间。

5. HTTP vs HTTPS

  • HTTPS = HTTP + SSL/TLS 加密。
  • 加密流程
    1. 客户端发送请求,服务器返回证书。
    2. 客户端验证证书,生成对称密钥并用公钥加密发送。
    3. 服务器用私钥解密,后续通信使用对称加密。
  • HTTP问题:无状态,明文传输,不安全
  • HTTP的风险:窃听、篡改、冒充
  • HTTPS如何解决的:信息加密、校验机制、身份证书

6. HTTP 缓存机制

  • ​强制缓存​(无需请求服务器):
    • Cache-Control: max-age=3600(优先级高于 Expires)。
  • 协商缓存​(需请求服务器验证):
    • Last-Modified + If-Modified-Since(时间戳)。
    • ETag + If-None-Match(唯一标识,精度更高)。

缓存流程
强缓存生效 → 直接返回本地缓存;
强缓存失效 → 发起请求,验证协商缓存 → 返回 304 或新内容。


7. HTTP/1.1 vs HTTP/2 vs HTTP/3

  • HTTP/1.1
    • 持久连接(默认 Connection: keep-alive)。
    • 队头阻塞(同一连接需顺序处理请求)。
  • HTTP/2
    • 多路复用(一个连接并行处理多个请求)。
    • 头部压缩(HPACK)。
    • 二进制传输。
    • 服务器推送(Server Push)。
  • HTTP/3
    • 基于 ​QUIC 协议​(UDP 实现,解决队头阻塞)。
    • 更快握手(0-RTT)。

8. 安全相关

  • CSRF(跨站请求伪造)​
    • 防御:Token 验证、SameSite Cookie 属性。
  • XSS(跨站脚本攻击)​
    • 防御:输入过滤、输出转义、CSP(内容安全策略)。

9. Cookie 和 Session

  • Cookie:客户端存储,通过 Set-Cookie 设置,每次请求自动携带。
  • Session:服务端存储用户状态,Session ID 通过 Cookie 传递。
  • 区别
    • Cookie 不安全(可篡改),Session 较安全但需服务器存储。
    • 分布式系统中 Session 需共享存储(如 Redis)。

10. RESTful API 设计

  • 资源定位:URL 表示资源(如 /users/123)。
  • HTTP 方法对应操作:GET(查)、POST(增)、PUT(改)、DELETE(删)。
  • 状态码语义化:200(成功)、201(创建)、400(错误请求)等。
  • 版本控制:通过 URI(/v1/users)或头部(Accept-Version: v1)。

11. 性能优化

  • 减少请求次数:合并资源(CSS/JS)、雪碧图。
  • 使用 CDN 加速静态资源。
  • 压缩资源:Gzip、Brotli。
  • 启用 HTTP/2 多路复用。

12.http与websocket

  • websocket是全双工通信,适用于实时应用

高频面试题

  1. GET 和 POST 的区别?
  2. HTTP 状态码 301 和 302 的区别?
  3. 如何实现 Cookie 的安全性(Secure/HttpOnly/SameSite)?
  4. 浏览器缓存机制是怎样的?
  5. HTTP/2 如何提升性能?
  6. HTTP如何解决“粘包”的问题的?
    1. HTTP 协议通过设置回车符、换行符作为 HTTP header 的边界,通过 Content-Length 字段作为HTTP body 的边界,这两个方式都是为了解决“粘包”的问题。

1.HTTPS的连接是如何建立的?

步骤一:TCP 连接建立
  • 客户端向服务器发起 HTTPS 请求(默认端口 443),开始 TCP 三次握手。

步骤二:TLS 握手(密钥协商)​
  1. Client Hello

    • 客户端发送支持的 TLS 版本、加密套件列表(如 RSA、ECDHE)、客户端随机数(Client Random)。
  2. Server Hello

    • 服务器选择加密套件,返回服务器随机数(Server Random)和数字证书(包含公钥、域名、颁发机构等信息)。
  3. 证书验证

    • 客户端验证证书的合法性(如是否过期、域名匹配、证书链是否可信等)。
  4. 生成预主密钥

    • 客户端生成一个随机数 ​预主密钥(Pre-Master Secret)​,用服务器公钥加密后发送给服务器。
  5. 生成会话密钥

    • 服务器用私钥解密获取预主密钥,结合 Client Random 和 Server Random,双方通过算法生成相同的 ​对称会话密钥(Session Key)​

步骤三:加密通信
  • 后续所有 HTTP 数据均使用 ​对称加密(如 AES)​ 传输,会话密钥仅在此次连接中有效,确保高效和安全。

关键词:

  • 非对称加密:用于安全交换对称密钥(RSA/ECDHE)。
  • 对称加密:用于高效加密实际数据(AES)。
  • 证书验证:防止中间人攻击,确保服务器身份可信。

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

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

相关文章

特殊行车记录仪DAT视频丢失的恢复方法

行车记录仪是一种常见的车载记录仪,和常见的“小巧玲珑”的行车记录仪不同,一些特种车辆使用的记录仪的外观可以用“笨重”来形容。下边我们来看看特种车载行车记录仪删除文件后的恢复方法。 故障存储: 120GB存储设备/文件系统:exFAT /簇大小:128KB 故…

数据库中不存在该字段

mybatisplus 定义的类中某些字段是数据库里面没有的,我们可用tablefield(existfalse)来注解,演示如下:

吾爱出品,文件分类助手,高效管理您的 PC 资源库

在日常使用电脑的过程中,文件杂乱无章常常让人感到困扰。无论是桌面堆积如山的快捷方式,还是硬盘中混乱的音频、视频、文档等资源,都急需一种高效的整理方法。文件分类助手应运而生,它是一款文件管理工具,能够快速、智…

关于瑞芯微开发工具(RKDevTool)刷机下载Boot失败原因的研究

昨天发了文章《网心云OEC/OEC-turbo刷机问题——刷机教程、救砖方法、技术要点及下载boot失败异常解决尝试》,其中有关于刷机各种问题的一些解决方法。 网心云OEC/OEC-turbo刷机问题——刷机教程、救砖方法、技术要点及下载boot失败异常解决尝试-CSDN博客文章浏览阅…

web爬虫笔记:js逆向案例十一 某数cookie(补环境流程)

web爬虫笔记:js逆向案例十一 某数cookie(补环境流程) 一、获取网页数据请求流程 二、目标网址、cookie生成(逐步分析) 1、目标网址:aHR0cHM6Ly9zdWdoLnN6dS5lZHUuY24vSHRtbC9OZXdzL0NvbHVtbnMvNy9JbmRleC5odG1s 2、快速定位入口方法 1、通过脚本监听、hook_cookie等操作可…

Excel多级联动下拉菜单的自动化设置(使用Python中的openpyxl模块)

1 主要目的 在Excel中,经常会遇到需要制作多级联动下拉菜单的情况,要求单元格内填写的内容只能从指定的多个选项中进行选择,并且需要设置多级目录,其中下级目录的选项内容要根据上级目录的填写内容确定,如下图所示&am…

excalidraw画图工具——背景画布有无格子设置

服啦找了大半天,愣是没找到 toggle grid : 切换格子… Excalidraw的背景格子 只要右键,将这个勾取消就好了?

计算机组成原理———I\O系统精讲<1>

本篇文章主要介绍输入输出系统的发展概况 一.输入输出系统的发展概况 1.早期阶段 该阶段的特点是I/O设备与主存交换信息都必须通过CPU 当时的I/O设备有如下几个特点: (1)每个I\O设备都必须配有一套独立的逻辑电路与CPU相连,用来…

ENSP学习day9

ACL访问控制列表实验 ACL(Access Control List,访问控制列表)是一种用于控制用户或系统对资源(如文件、文件夹、网络等)访问权限的机制。通过ACL,系统管理员可以定义哪些用户或系统可以访问特定资源&#x…

【C++动态规划 数学】1039. 多边形三角剖分的最低得分|2130

本文涉及知识点 C动态规划 数学 LeetCode1039. 多边形三角剖分的最低得分 你有一个凸的 n 边形,其每个顶点都有一个整数值。给定一个整数数组 values ,其中 values[i] 是第 i 个顶点的值(即 顺时针顺序 )。 假设将多边形 剖分 …

5.go切片和map

切片的概念 数组和切片相比较切片的长度是不固定的,可以追加元素,在追加时可能会使切片的容量增大,所以可以将切片理解成 "动态数组",但是,它不是数组,而是构建在数组基础上的更高级的数据结构。…

【Linux网络-多路转接select】

代码:https://gitee.com/nanyi-c/linux/tree/master/day50 一、I/O多路转接之select 1.初始select 系统提供select函数来实现多路复用输入/输出模型 select系统调用是用来让我们的程序监视多个文件描述符的状态变化的程序会停在select这里等待,直到被…

cmd命令查看电脑的CPU、内存、存储量

目录 获取计算机硬件的相关信息的命令分别的功能结果展示结果说明获取计算机硬件的相关信息的命令 wmic cpu get name wmic memorychip get capacity wmic diskdrive get model,size,mediaType分别的功能 获取计算机中央处理器(CPU)的名称 获取计算机内存(RAM)芯片的容量…

LVS的 NAT 模式实现 3 台RS的轮询访问

使用LVS的 NAT 模式实现 3 台RS的轮询访问 1.配置 RS(NAT模式)2. 配置 LVS 主机(仅主机、NAT模式)2.1 配置仅主机网卡(192.168.66.150/24 VIP )2.2 配置 NAT 网卡(192.168.88.6/24 DIP&#xff…

phpcms版AI自动发文插件,自动创作,自动配图,自动发布,支持多种大模型

phpcms版本的AI自动发文插件1.0.0版,支持自动写文章,自动配图,自动发布。目前支持DeepSeek,豆包,通义千问,文心一言,讯飞星火,KIMI,腾讯混元登大模型AI。同时有自定义字段…

C语言判断闰年相关问题

一、简单闰年问题引入 写一个判断年份是否为闰年的程序? 运行结果: 二、闰年问题进阶 使用switch语句根据用户输入的年份和月份,判断该月份有多少天? 第一种写法(判断年份写在switch的case的里面): 运行结果: 第二种解法(先判断闰年): 运行结果: 三、补充 switch中的ca…

数模转换电路(D/A转换器)

将数字信号转换成模拟信号称为数/模转换, 简称D/A(Digital to Analog)转换,实现 D/A 转换的器件称为D/A转换器,简称 DAC(Digital-Analog Converter)。 将模拟信号转换成数字信号称为模/数转换, 简称A/D&a…

网络基础-路由器和交换机工作配置

三、路由器和交换机的工作原理配置以及华为体系下的小型网络的搭建 3.1路由基础 3.1.1数据转发 通过链路层交换机和网络层路由器进行数据转发 交换机(链路层)mac地址表的数据转发路由器(网络层) ip路由表的数据转发 隔离广播域…

uv包简单使用案例

uv由Charlie Marsh开发,是Astral Tool的一个快速Python包安装器和解析器。它类似于pip和pip-tools,但速度更快。此外,uv还支持虚拟环境管理,替代venv和virtualenv。 参考:https://github.com/astral-sh/uv 安装&#x…

JAVA学习*String类

String类 基本知识 String类的构造方法 String类的构造方法有很多,我们需要掌握常见的构造方法,来赋初识值。 1、new一个String类的对象 String name new String("张三");2、使用字符串常量进行赋值 String name "张三";相当…