当前位置:首页 > 文章列表 > 文章 > python教程 > 拒绝服务正则表达式破坏了 FastAPI 安全性

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

来源:dev.to 2024-08-01 18:12:55 0浏览 收藏

今日不肯埋头,明日何以抬头!每日一句努力自己的话哈哈~哈喽,今天我将给大家带来一篇《拒绝服务正则表达式破坏了 FastAPI 安全性》,主要内容是讲解等等,感兴趣的朋友可以收藏或者有更好的建议在评论提出,我都会认真看的!大家一起进步,一起学习!

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

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

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

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

import re
pattern = 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 fastapi
app = 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 test

testing /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.0

organization:      liran.tal
package manager:   pip
target file:       requirements.txt
project 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 annotated
from fastapi.responses import htmlresponse
from fastapi import fastapi,form
from pydantic import basemodel

class item(basemodel):
    username: str

app = 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 安全性》的介绍应该让你收获多多了吧!欢迎大家收藏或分享给更多需要学习的朋友吧~golang学习网公众号也会发布文章相关知识,快来关注吧!

版本声明
本文转载于:dev.to 如有侵犯,请联系study_golang@163.com删除
java框架如何构建分布式系统的优缺点java框架如何构建分布式系统的优缺点
上一篇
java框架如何构建分布式系统的优缺点
在 Javascript 中使用此函数将字符串转换为驼峰命名法
下一篇
在 Javascript 中使用此函数将字符串转换为驼峰命名法
查看更多
最新文章
查看更多
课程推荐
  • 前端进阶之JavaScript设计模式
    前端进阶之JavaScript设计模式
    设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
    542次学习
  • GO语言核心编程课程
    GO语言核心编程课程
    本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
    508次学习
  • 简单聊聊mysql8与网络通信
    简单聊聊mysql8与网络通信
    如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
    497次学习
  • JavaScript正则表达式基础与实战
    JavaScript正则表达式基础与实战
    在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
    487次学习
  • 从零制作响应式网站—Grid布局
    从零制作响应式网站—Grid布局
    本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
    484次学习
查看更多
AI推荐
  • 毕业宝AIGC检测:AI生成内容检测工具,助力学术诚信
    毕业宝AIGC检测
    毕业宝AIGC检测是“毕业宝”平台的AI生成内容检测工具,专为学术场景设计,帮助用户初步判断文本的原创性和AI参与度。通过与知网、维普数据库联动,提供全面检测结果,适用于学生、研究者、教育工作者及内容创作者。
    18次使用
  • AI Make Song:零门槛AI音乐创作平台,助你轻松制作个性化音乐
    AI Make Song
    AI Make Song是一款革命性的AI音乐生成平台,提供文本和歌词转音乐的双模式输入,支持多语言及商业友好版权体系。无论你是音乐爱好者、内容创作者还是广告从业者,都能在这里实现“用文字创造音乐”的梦想。平台已生成超百万首原创音乐,覆盖全球20个国家,用户满意度高达95%。
    29次使用
  • SongGenerator.io:零门槛AI音乐生成器,快速创作高质量音乐
    SongGenerator
    探索SongGenerator.io,零门槛、全免费的AI音乐生成器。无需注册,通过简单文本输入即可生成多风格音乐,适用于内容创作者、音乐爱好者和教育工作者。日均生成量超10万次,全球50国家用户信赖。
    27次使用
  •  BeArt AI换脸:免费在线工具,轻松实现照片、视频、GIF换脸
    BeArt AI换脸
    探索BeArt AI换脸工具,免费在线使用,无需下载软件,即可对照片、视频和GIF进行高质量换脸。体验快速、流畅、无水印的换脸效果,适用于娱乐创作、影视制作、广告营销等多种场景。
    30次使用
  • SEO标题协启动:AI驱动的智能对话与内容生成平台 - 提升创作效率
    协启动
    SEO摘要协启动(XieQiDong Chatbot)是由深圳协启动传媒有限公司运营的AI智能服务平台,提供多模型支持的对话服务、文档处理和图像生成工具,旨在提升用户内容创作与信息处理效率。平台支持订阅制付费,适合个人及企业用户,满足日常聊天、文案生成、学习辅助等需求。
    32次使用
微信登录更方便
  • 密码登录
  • 注册账号
登录即同意 用户协议隐私政策
返回登录
  • 重置密码