拒绝服务正则表达式破坏了 FastAPI 安全性

欢迎各位开发者!在这篇博文中,我们将深入研究应用程序安全领域,特别关注可能恶化 fastapi 安全性的漏洞:由不安全的正则表达式 (regex) 导致的拒绝服务 (dos)。我们将探讨构造不良的正则表达式如何导致所谓的正则表达式拒绝服务 (redos)(一种 dos 攻击),以及如何使用强大的开发人员安全工具 — snyk 来识别和缓解这些漏洞。

了解 redos 对 python 中 fastapi 安全性的影响

python 是最流行的编程语言之一,拥有庞大的包和库生态系统。虽然这些软件包让我们作为开发人员的生活变得更轻松,但如果没有得到适当的保护,它们也会带来潜在的风险。随着软件开发的快速步伐,软件包经常更新,新版本发布,有时会在不知不觉中引入安全风险。

其中一个风险是潜在的 redos 攻击,这是一种 dos 攻击,攻击者向需要很长时间才能评估的正则表达式提供恶意输入。这会导致应用程序变得无响应或显着减慢,这可能会产生严重的影响,从用户体验下降到应用程序完全失败。

import repattern = re.compile("^(a+)+$")def check(input):    return bool(pattern.match(input))check("a" * 3000 + "!")

上面的代码中,正则表达式^(a+)+$容易受到redos攻击。如果攻击者提供一串“a”后跟一个非“a”字符,则正则表达式需要很长时间来评估,从而有效地导致 dos。

snyk 如何保护您的 fastapi python 应用程序

snyk 是一款开发人员优先的安全工具,可以扫描您的 python 代码以查找潜在的 redos 漏洞。它提供已识别漏洞的详细报告并推荐最合适的修复方案。

# after installing snyk and setting up the snyk cli# you can scan your project:$ snyk test 

此命令将扫描您的第三方依赖项清单(通常在requirements.txt 文件中),并提供所有已识别漏洞的报告,包括潜在的redos 漏洞。立即注册免费的 snyk 帐户,开始扫描您的 python 项目是否存在 redos 和其他漏洞。

了解此类漏洞的影响以及如何缓解它们对于维护安全的 python 应用程序至关重要。这就是 snyk 这样的工具派上用场的地方。 snyk open source 可以帮助识别和修复 python 包中的安全漏洞,包括可能导致 redos 攻击的不安全正则表达式。

让我们仔细看看如何使用 snyk 识别和缓解 fastapi python web 应用程序中的此类漏洞。

fastapi 安全漏洞 cve-2024-24762

fastapi 是一个现代的高性能 web 框架,用于基于标准 python 类型提示使用 python 构建 api。它的主要特点是速度以及快速、轻松地构建强大 api 的能力,使其成为需要构建高性能 restful api 的 python 开发人员的热门选择。

fastapi 通过提供开箱即用的路由机制、序列化/反序列化和验证来简化构建 api 的过程。它构建在用于 web 部分的 python 项目 starlette 和用于数据部分的 pydantic 之上。这允许开发人员利用 python 3.6 及更高版本中提供的异步功能。

作为示例,可以使用以下代码片段来完成使用 fastapi python web 应用程序创建简单的 api:

from fastapi import fastapiapp = fastapi()@app.get("/")def read_root():    return {"hello": "world"}

虽然 fastapi 是一个强大且敏捷的 api 开发工具,但它并非没有漏洞。其中之一是 cve-2024-24762 漏洞。这是一个拒绝服务漏洞,源自 python 包 python-multipart 使用的正则表达式。

python-multipart 依赖项是一个用于解析 multipart/form 数据的 python 库。它通常用作 fastapi 中的依赖项来管理表单数据。

当攻击者发送恶意字符串,导致 python-multipart 中的正则表达式消耗大量 cpu,从而导致拒绝服务 (dos) 时,就会出现该漏洞。这也称为正则表达式拒绝服务 (redos)。

python 开发人员如何缓解此漏洞?第一步是识别项目中的漏洞。这可以使用 snyk cli 工具来完成。

$ snyk test

检测此类漏洞需要扫描项目的依赖项,这将提供项目依赖项中所有漏洞的报告。

snyk测试命令的输出发现漏洞:

snyk testtesting /users/lirantal/projects/repos/fastapi-vulnerable-redos-app...tested 13 dependencies for known issues, found 1 issue, 1 vulnerable path.issues to fix by upgrading dependencies:  upgrade fastapi@0.109.0 to fastapi@0.109.1 to fix  ✗ regular expression denial of service (redos) (new) [high severity][https://security.snyk.io/vuln/snyk-python-fastapi-6228055] in fastapi@0.109.0    introduced by fastapi@0.109.0organization:      liran.talpackage manager:   piptarget file:       requirements.txtproject name:      fastapi-vulnerable-redos-app

要修复该漏洞,您可以升级到已修复该漏洞的 python-multipart 包和 fastapi 的较新版本,这些版本是 snyk 建议的。

构建和破坏 fastapi 安全性:分步指南

我们的第一步是建立一个新的 python 项目。我们需要安装 fastapi 以及托管它的服务器。 uvicorn 是服务器的一个不错的选择,因为它是轻量级的并且与 fastapi 配合良好。

首先使用 pip 安装 fastapi、python-multipart 和 uvicorn:

pip install fastapi==0.109.0 uvicorn python-multipart==0.0.6

接下来,为您的项目创建一个新目录,并在该目录中为您的 fastapi 应用程序创建一个新文件。你可以将其命名为 main.py.

编写 fastapi python 代码

现在我们准备编写 fastapi 应用程序代码了。打开main.py并添加以下python代码:

from typing import annotatedfrom fastapi.responses import htmlresponsefrom fastapi import fastapi,formfrom pydantic import basemodelclass item(basemodel):    username: strapp = fastapi()@app.get("/", response_class=htmlresponse)async def index():    return htmlresponse("test", status_code=200)@app.post("/submit/")async def submit(username: annotated[str, form()]):    return {"username": username}@app.post("/submit_json/")async def submit_json(item: item):    return {"username": item.username}

这个简单的 fastapi 应用程序有多个路由 (/),包括 /submit,它使用多部分形式。当收到 post 请求时,提交路由会返回提交的用户名。

启动服务器并运行应用程序

编写完 fastapi 应用程序代码后,我们现在可以启动 uvicorn 服务器并运行我们的应用程序。

使用以下命令启动服务器:

uvicorn main:app --reload

您应该看到一个输出,表明服务器正在运行。您可以通过在 web 浏览器中导航到 http://localhost:8000 来测试您的应用程序。页面上应显示“测试”消息。

通过 redos 攻击破坏 fastapi 安全

现在我们的 fastapi 应用程序正在运行,我们可以测试它是否存在漏洞。我们将在 http 请求中使用 redos 攻击负载来利用解析 content-type 标头值的 python-multipart 包中的漏洞。

如果您安装了curl程序,请在终端中运行以下命令:

curl -v -x 'post' -h $'content-type: application/x-www-form-urlencoded; !="\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\' --data-binary 'input=1' 'http://localhost:8000/submit/'

使用 snyk 保护您的 fastapi 应用程序

正如您现在所看到的,开源依赖项在构建 python 应用程序中发挥着关键作用。然而,这些第三方依赖项有时可能成为漏洞的滋生地,从而构成重大的安全威胁。在这种背景下,snyk open source 作为一个强大的工具应运而生,可以帮助开发人员有效地识别和修复安全问题。

想象一下,当您编写 python 代码时,您可以快速找到 ide 面板中已有的 fastapi 安全漏洞,而不是等到安全扫描程序在稍后阶段发现它。

snyk ide 扩展是免费的,如果您使用 pycharm,您可以在插件视图中搜索 snyk 并直接从那里下载。如果您使用 vs code,您也可以直接从 ide 在扩展市场中找到它。

拒绝服务正则表达式破坏了 FastAPI 安全性

snyk 开源及其功能简介

snyk open source 是一个强大的工具,用于发现和解决开源依赖项和容器镜像中的漏洞。它旨在与现有代码库和 ci/cd 系统轻松集成,使其成为开发人员的便捷工具。它提供了已知漏洞的综合数据库,使开发人员能够主动解决潜在的安全漏洞。

有关如何使用 snyk 扫描 python 依赖项中的漏洞的分步指南

要使用 snyk 扫描 python 依赖项是否存在漏洞,首先需要安装 snyk cli。您可以使用指南中的方法之一来执行此操作,或者如果您有 node.js 环境,则可以使用 npm install -g snyk 快速安装 snyk,然后运行 ​​snyk auth 进行身份验证。

安装后,您可以使用 snyk test 命令检查您的 python 项目是否存在漏洞:

snyk test --all-projects

snyk 然后将扫描您的所有依赖项并将其与漏洞数据库进行比较。如果发现任何问题,snyk 将提供详细报告,其中包含有关漏洞、其严重性和可能的​​修复方法的信息。

使用 snyk 监控您的项目对于维护应用程序的安全至关重要。使用 snyk,您不仅可以检测漏洞,还可以应用自动修复,这可以节省您的时间和资源。

此外,snyk 还提供漏洞警报,通知您可能影响您的项目的新漏洞。这使您能够领先一步并在安全问题被利用之前解决它们。

使用 snyk monitor 命令,您可以拍摄当前项目依赖项的快照并监控它们是否存在漏洞:

snyk monitor

如何将 snyk 与 git 存储库集成

将 snyk 与您的 git 存储库集成后,您可以自动扫描每个提交是否存在漏洞。这可以通过在存储库设置中将 snyk 添加为 webhook 来完成。

拒绝服务正则表达式破坏了 FastAPI 安全性
完成此操作后,每次推送到您的存储库都会触发 snyk 扫描,帮助您尽早捕获并修复漏洞。

总而言之,snyk open source 是维护 python 项目安全性的宝贵工具。通过扫描漏洞、监控项目以及与 git 存储库集成,snyk 使您能够维护强大、安全的代码库。如果您还没有注册一个免费的 snyk 帐户,请立即开始保护您的应用程序。

以上就是拒绝服务正则表达式破坏了 FastAPI 安全性的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1348685.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
成为百万富翁
上一篇 2025年12月13日 12:15:41
什么是 Django Rest 框架?
下一篇 2025年12月13日 12:16:00

相关推荐

  • 开源免费PHP工具 PHP开发效率提升利器

    推荐开源免费PHP开发工具以提升效率:VS Code、Sublime Text轻量高效,PhpStorm专业强大;调试用Xdebug、Kint、Ray;依赖管理选Composer;代码质量工具包括PHPStan、Psalm、PHP_CodeSniffer;数据库管理可用%ignore_a_1%MyA…

    2026年5月10日
    000
  • Matplotlib 地图中多类型图例的创建与优化

    Matplotlib 地图中多类型图例的创建与优化Matplotlib 地图中多类型图例的创建与优化Matplotlib 地图中多类型图例的创建与优化Matplotlib 地图中多类型图例的创建与优化

    本教程旨在解决matplotlib地图可视化中,如何在一个图例中同时展示颜色块(如区域分类)和自定义标记(如特定兴趣点)的问题。文章详细介绍了当传统`patch`对象无法正确显示标记时,如何利用`matplotlib.lines.line2d`创建标记图例句柄,并将其与颜色块图例句柄合并,从而生成一…

    2026年5月10日 用户投稿
    100
  • 利用海象运算符简化条件赋值:Python教程与最佳实践

    本文旨在探讨Python中海象运算符(:=)在条件赋值场景下的应用。通过对比传统if/else语句与海象运算符,以及条件表达式,分析海象运算符在简化代码、提高可读性方面的优势与局限性。并通过具体示例,展示如何在列表推导式等场景下合理使用海象运算符,同时强调其潜在的复杂性及替代方案,帮助开发者更好地掌…

    2026年5月10日
    000
  • RichHandler与Rich Progress集成:解决显示冲突的教程

    在使用rich库的`richhandler`进行日志输出并同时使用`progress`组件时,可能会遇到显示错乱或溢出问题。这通常是由于为`richhandler`和`progress`分别创建了独立的`console`实例导致的。解决方案是确保日志处理器和进度条组件共享同一个`console`实例…

    2026年5月10日
    000
  • 使用 Jupyter Notebook 进行探索性数据分析

    Jupyter Notebook通过单元格实现代码与Markdown结合,支持数据导入(pandas)、清洗(fillna)、探索(matplotlib/seaborn可视化)、统计分析(describe/corr)和特征工程,便于记录与分享分析过程。 Jupyter Notebook 是进行探索性…

    2026年5月10日
    000
  • Python命令怎样使用profile分析脚本性能 Python命令性能分析的基础教程

    使用Python的cProfile模块分析脚本性能最直接的方式是通过命令行执行python -m cProfile your_script.py,它会输出每个函数的调用次数、总耗时、累积耗时等关键指标,帮助定位性能瓶颈;为进一步分析,可将结果保存为文件python -m cProfile -o ou…

    2026年5月10日
    000
  • Python递归函数追踪与性能考量:以序列打印为例

    本文深入探讨了Python中一种递归打印序列元素的方法,并着重演示了如何通过引入缩进参数来有效追踪递归函数的执行流程和参数变化。通过实际代码示例,文章揭示了递归调用可能带来的潜在性能开销,特别是对调用栈空间的需求,以及Python默认递归深度限制可能导致的错误,为读者提供了理解和优化递归算法的实用见…

    2026年5月10日
    000
  • python中zip函数详解 python多序列压缩zip函数应用场景

    zip函数的应用场景包括:1) 同时遍历多个序列,2) 合并多个列表的数据,3) 数据分析和科学计算中的元素运算,4) 处理csv文件,5) 性能优化。zip函数是一个强大的工具,能够简化代码并提高处理多个序列时的效率。 在Python中,zip函数是一个非常有用的工具,它能够将多个可迭代对象打包成…

    2026年5月10日
    000
  • 谷歌浏览器如何截图 谷歌浏览器页面截图技巧

    谷歌浏览器如何截图 谷歌浏览器页面截图技巧谷歌浏览器如何截图 谷歌浏览器页面截图技巧谷歌浏览器如何截图 谷歌浏览器页面截图技巧谷歌浏览器如何截图 谷歌浏览器页面截图技巧

    使用谷歌浏览器的开发者工具截图步骤:1. 按ctrl+shift+i(windows/linux)或cmd+option+i(mac)打开开发者工具。2. 点击右上角三个点,选择”更多工具”,再选择”截图”。3. 选择截取整个页面。推荐的谷歌浏览器扩展…

    2026年5月10日 用户投稿
    100
  • Python中怎样使用pymongo?

    在python中使用pymongo可以轻松地与mongodb数据库进行交互。1)安装pymongo:pip install pymongo。2)连接到mongodb:from pymongo import mongoclient; client = mongoclient(‘mongod…

    2026年5月10日
    000
  • JavaScript计算器开发:解决数值显示与初始化问题

    本教程深入探讨了使用JavaScript构建计算器时常见的数值显示异常问题,特别是由于类属性未初始化导致的`Cannot read properties of undefined`错误。我们将详细分析问题根源,并通过在构造函数中调用初始化方法来解决该问题,同时优化显示逻辑,确保计算器功能稳定且界面显…

    2026年5月10日
    000
  • Python 函数参数类型:如何使用可变参数和动态参数?

    python 中的参数类型:关键词参数、可变参数和动态参数 在 python 中,函数的参数可以分为以下几种类型: 关键词参数(kw)**:这些参数具有名称,并且在调用函数时明确指定。可变参数(*args):这些参数没有名称,允许函数接受任意数量的位置参数。它们将被收集到一个元组中。动态参数(kwa…

    2026年5月10日
    000
  • NextAuth getToken 在服务端返回 null 的问题排查与解决

    问题描述 在使用 Next.js 和 NextAuth 构建应用程序时,有时需要在服务端获取用户的身份验证信息。getToken 函数是 NextAuth 提供的一个便捷方法,用于从请求中提取 JWT (JSON Web Token)。然而,在某些情况下,尤其是在使用 getServerSidePr…

    2026年5月10日
    000
  • pycharm解析器怎么添加 解析器添加详细流程

    在pycharm中添加解析器的步骤包括:1) 打开pycharm并进入设置,2) 选择project interpreter,3) 点击齿轮图标并选择add,4) 选择解析器类型并配置路径,5) 点击ok完成添加。添加解析器后,选择合适的类型和版本,配置环境变量,并利用解析器的功能提高开发效率。 在…

    2026年5月10日
    000
  • python中numpy的用法

    NumPy是Python中用于科学计算的强大库,它提供了以下功能:多维数组处理矩阵运算快速傅里叶变换(FFT)线性代数随机数生成 NumPy在Python中的强大功能 NumPy是Python中用于科学计算的一个强大且灵活的库。它提供了用于处理多维数组和矩阵的一组高效工具,是数据分析和机器学习项目的…

    2026年5月10日
    100
  • HTML文档如何工作?如何编辑HTML格式文件?

    HTML文档如何工作?如何编辑HTML格式文件?HTML文档如何工作?如何编辑HTML格式文件?HTML文档如何工作?如何编辑HTML格式文件?HTML文档如何工作?如何编辑HTML格式文件?

    浏览器解析和渲染html的过程包括:1. 解析html构建dom树;2. 结合css构建渲染树;3. 布局计算元素位置;4. 绘制像素到屏幕。编辑html可使用记事本、vs code、sublime text等文本或代码编辑器,其中vs code因语法高亮、自动补全和插件生态成为主流选择。标准htm…

    2026年5月10日 用户投稿
    000
  • GolangWeb项目异常捕获与日志记录

    答案:通过中间件使用defer和recover捕获panic,结合zap等结构化日志库记录请求链路信息,为每个请求生成trace ID,实现异常捕获与可追踪日志,提升系统稳定性与可观测性。 在Go语言Web项目中,异常捕获与日志记录是保障系统稳定性和可维护性的关键环节。Go本身没有像其他语言那样的t…

    2026年5月10日
    000
  • python如何捕获所有类型的异常_python try except捕获所有异常的方法

    答案:捕获所有异常推荐使用except Exception as e,可捕获常规错误并记录日志,避免影响程序正常退出;需拦截系统信号时才用except BaseException as e。 在Python中,要捕获所有类型的异常,最常见且推荐的方法是使用 except Exception as e…

    2026年5月10日
    000
  • python中f怎么用

    f-字符串是 Python 3.6 中引入的格式化字符串语法糖,提供了简洁且安全的方式来插入表达式和变量。f-字符串以字符串前缀 f 为标志,使用大括号包含表达式或变量。f-字符串支持条件表达式和格式规范符,提供了更大的灵活性、安全性、可读性和易维护性。 在 Python 中使用 f-字符串 f-字…

    2026年5月10日
    100
  • 怎么在手机上把XML文件转换为PDF?

    不可能直接在手机上用单一应用完成 XML 到 PDF 的转换。需要使用云端服务,通过两步走的方式实现:1. 在云端转换 XML 为 PDF,2. 在手机端访问或下载转换后的 PDF 文件。 怎么在手机上把XML文件转换为PDF? 这问题问得好,比直接问“怎么转换”有深度多了!因为它触及了移动端环境的…

    2026年5月10日
    000

发表回复

登录后才能评论
关注微信