DAST 已死,为何业务逻辑安全测试成为焦点

2024-04-21 08:36

本文主要是介绍DAST 已死,为何业务逻辑安全测试成为焦点,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

“DAST 已死”——这句话每年都会出现在社交媒体和网络安全新闻通讯中。但如果到了 2024 年,它终于实现了呢?

DAST,动态应用程序安全测试(尽管我们在过去几周内看到了一个新术语“动态 API 安全测试”),在过去十年中一直是应用程序安全测试的基石,但现在是时候让路了下一代应用程序安全测试:业务逻辑安全测试。

为什么理解业务逻辑安全问题对于安全工程师来说变得越来越重要?在这篇文章中,我决定解释这种日益重要的背后的原因。

作为安全人员,我们可能会停止关注基本问题。我们将研究我们的工具很难找到的更困难的问题。就像业务逻辑问题一样……

SDLC 中的安全性:“左移”趋势

在敏捷环境中,开发人员会在我自己的团队中不断更新他们的应用程序(或后端、服务……无论他们如何称呼它们!),有时甚至每天更新。每年进行一两次渗透测试的传统方法不再具有任何意义,因为每次构建都会引入新的漏洞。几年前,手动渗透测试的过时本质对我来说变得非常明显(这也是我决定构建 Escape 的原因之一)。这就是为什么“左移”趋势开始兴起,市场上的安全解决方案必须适应。

适应SDLC的安全解决方案

DAST 工具的最初好处很明显 - 它是唯一可以检测正在运行的应用程序中的漏洞的解决方案(它可以查看应用程序在其环境中的行为方式)。另一方面,软件组合分析 (SCA) 工具主要侧重于列出依赖项中的已知漏洞,而不是评估应用程序的业务逻辑。这一限制缩小了他们识别应用程序核心功能中潜在风险的范围。

很多时候,人们往往过度关注 SDLC 的左侧,而对 SDLC 的右侧关注不够。您可以在供应商中看到它。因此,DAST 工具通常效率非常低,而且它们往往不会产生任何对组织和安全工程师都没有用的东西。所以,很多时候人们只是倾向于说,让我们把 SAST 放在适当的位置,让我们把所有的安全护栏放在左边,而不用担心右边。 

静态应用程序安全测试 (SAST) 工具虽然有用,但由于无法评估运行状态下的应用程序,通常会产生大量误报和漏报。静态分析与应用程序实际运行时行为之间的这种差异阻碍了 SAST 工具查明真正漏洞的有效性。

交互式应用程序安全测试 (IAST) 工具处于中间立场,可在应用程序运行时深入了解应用程序漏洞,从而比 SAST 工具提高准确性。然而,IAST 实现很复杂,并且会在测试期间引入性能开销,因为该工具会主动监视和分析应用程序的行为。

运行时应用程序自我保护 (RASP) 工具面临着不同的挑战,因为它们缺乏生成流量的能力。因此,他们只能在攻击已经损害了应用程序及其基础设施后才能识别漏洞,这使得他们与 DAST 工具相比在威胁缓解方面缺乏主动性。

Escape 的 DAST 与其他安全工具

因此,DAST 出现的时机非常完美:构建完成后,代码刚刚生成且正在运行。它可以在发布后几秒钟无缝集成到 CI/CD 管道或开发/生产环境中,以免为时已晚。作为黑盒测试,它不需要访问代码和流量。

DAST 名声不好却是罪有应得

免责声明:在这一部分中,我什至不会介绍像 Rapid7、Qualys 或 Nessus 这样的 Generalist DAST,它们不测试应用程序层,而只测试网络层;我将重点关注用于测试 API 的 DAST。

1. DAST暴力请求未通过数据验证层

虽然 DAST 理论上是唯一具有完美时机和最有效的“左移”安全解决方案的解决方案,但它也有自己的一系列问题:

当前的 DAST 解决方案不够充分;他们生成毫无意义的请求。他们采用暴力模糊测试。在最好的情况下,它们采用架构(例如 REST API 的 OpenAPI 规范)作为输入来发送正确类型的数据。

然而,仅仅因为标记为电子邮件的字段被标记为字符串并不意味着发送无意义的字符串(例如r4d0omFu!1=1发送到电子邮件字段)是合乎逻辑的。

因此,DAST 中的请求不会通过数据验证层,因此它们会在没有进行任何测试的情况下被卡住。

这是OWASP ZAP(现在的 ZAP)等非常传统的解决方案的主要问题。如今,最著名的 API DAST 供应商只是包装 OWASP ZAP:StackHawk、Checkmarkx、Gitlab、Traceable 等 OWASP ZAP 和第三方服务。

实际上,正如我们的 Escape 与 ZAP 比较(即将在另一篇文章中推出)所证明的那样,大约 0% 的应用程序解析器被 OWASP ZAP 及其来自业务逻辑 POV 的包装器覆盖,这使得它们与 Rapid7、Qualys 一样无效,和 Nessus 用于测试 API。

2. DAST很笨,不会自动执行业务逻辑安全测试

正如微软的 Marina Polishuk 所强调的那样(她的论文“REST-ler:自动智能 REST API 模糊测试”是第一篇认真详细说明此问题的论文),DAST 无法生成和执行与业务逻辑一致的合法请求序列 API。

例如,DAST 无法充分测试特定端点,GET /user/{id}因为它不理解该端点应该{id}源自它之前创建或遇到的用户。因此,在这种情况下无法测试复杂的攻击场景。再次强调,OWASP ZAP 在这方面完全失败了。

有些工具(例如 Nuclei 或 bChecks)可以协助 API 业务逻辑,但不是自动的!事实上,这些解决方案更适合使用简单的指纹技术或手动复杂的业务逻辑(使用硬编码检查)自动评估应用程序的表面。最近的解决方案(例如 Akto)只是 Nuclei 等开源工具的包装。

特别是,Nuclei 和 bChecks 需要手动维护您的测试。这种方法与安全环境不太相符:由于应用程序每天更新,检查是否也应该每天更新和维护?谁负责在组织内实施和维护安全测试?正确评估应用程序及其业务逻辑的安全性需要评估数百种不同安全漏洞的数千种场景。

这将需要每天在每次更新时为每个 API 编写和维护无限数量的手动检查,适应 API 的新用例,每天了解新的 API 安全漏洞以支持新漏洞,实施和调整支票等,这是不现实的。

3.如果DAST声称评估业务逻辑,它需要您组织的数据

一些解决方案声称能够评估 API 的业务逻辑。然而,要做到这一点,他们需要在您的生产环境中有一个代理*,使用您组织的私有数据捕获所有流量和重播请求。

注意:让我们就该上下文中代理的定义达成一致。在 Escape,我们将代理视为安装在客户环境中的任何软件,旨在观察该环境的一部分或与该环境的一部分进行交互。因此,声称“无需代理即可部署[但]只是获取[组织] API流量的副本并将元数据发送到[其服务器]”的解决方案需要代理。

申明“通过与现有安全基础设施集成并实时阻止攻击来修复 API 漏洞,所有这些都无需部署代理或需要网络修改”的解决方案 1) 确实需要代理,2) 不执行业务逻辑测试,而是执行运行时保护。

然后,他们需要访问生产中的客户数据,出于隐私原因,这是侵入性的、过于复杂和危险的。

如果您考虑一下:每次部署测试应用程序的目标是特别关注应用程序的新功能。在这种情况下,使用流量没有任何意义,因为这些新功能尚未暴露给任何流量。 

4. 没有 DAST 真正支持 GraphQL 和其他现代 API

GraphQL 确实非常具体。市场上所有声称支持 GraphQL 的 DAST 解决方案实际上都像 OWASP ZAP 对待 REST API 一样对待 GraphQL。

这意味着没有解决方案尝试发送根据底层 API 的业务逻辑有意义的请求序列。特别是在 GraphQL 中,这些解决方案发送的请求没有考虑图特定的功能,如深度查询、递归查询、别名、批处理、片段等,() 也没有考虑其图性质隐含的众多访问控制问题。 

其他 API 类型如 gRPC、Websockets 等也有其特殊性,目前市场上还没有构建 DAST 解决方案来深入测试这些 API 类型的业务逻辑。

业务逻辑安全测试的本质转变

总之,我们所知道的用于 API 安全测试的 DAST 工具的时代即将结束。正如本文所强调的,DAST 在有效解决现代应用程序漏洞(特别是那些根植于业务逻辑的漏洞)方面的局限性已经变得越来越明显。

虽然 DAST 工具过去已经达到了其目的,但它们无法自动生成与 API 业务逻辑一致的有意义的流量,这凸显了对更先进方法的需求。

Escape 专有的业务逻辑安全测试算法植根于反馈驱动语义 API 探索 (FDSAE) 原则,为下一代安全测试方法铺平了道路。

通过自动生成针对每个 API 的具体细微差别而定制的合法流量,Escape 的解决方案使安全专业人员能够有效应对现代应用程序的挑战和复杂性。

随着公司继续在其开发流程中优先考虑安全性,业务逻辑安全测试无疑将成为确保 API 安全的中心舞台。

这篇关于DAST 已死,为何业务逻辑安全测试成为焦点的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/922632

相关文章

C#实现WinForm控件焦点的获取与失去

《C#实现WinForm控件焦点的获取与失去》在一个数据输入表单中,当用户从一个文本框切换到另一个文本框时,需要准确地判断焦点的转移,以便进行数据验证、提示信息显示等操作,本文将探讨Winform控件... 目录前言获取焦点改变TabIndex属性值调用Focus方法失去焦点总结最后前言在一个数据输入表单

如何测试计算机的内存是否存在问题? 判断电脑内存故障的多种方法

《如何测试计算机的内存是否存在问题?判断电脑内存故障的多种方法》内存是电脑中非常重要的组件之一,如果内存出现故障,可能会导致电脑出现各种问题,如蓝屏、死机、程序崩溃等,如何判断内存是否出现故障呢?下... 如果你的电脑是崩溃、冻结还是不稳定,那么它的内存可能有问题。要进行检查,你可以使用Windows 11

性能测试介绍

性能测试是一种测试方法,旨在评估系统、应用程序或组件在现实场景中的性能表现和可靠性。它通常用于衡量系统在不同负载条件下的响应时间、吞吐量、资源利用率、稳定性和可扩展性等关键指标。 为什么要进行性能测试 通过性能测试,可以确定系统是否能够满足预期的性能要求,找出性能瓶颈和潜在的问题,并进行优化和调整。 发现性能瓶颈:性能测试可以帮助发现系统的性能瓶颈,即系统在高负载或高并发情况下可能出现的问题

字节面试 | 如何测试RocketMQ、RocketMQ?

字节面试:RocketMQ是怎么测试的呢? 答: 首先保证消息的消费正确、设计逆向用例,在验证消息内容为空等情况时的消费正确性; 推送大批量MQ,通过Admin控制台查看MQ消费的情况,是否出现消费假死、TPS是否正常等等问题。(上述都是临场发挥,但是RocketMQ真正的测试点,还真的需要探讨) 01 先了解RocketMQ 作为测试也是要简单了解RocketMQ。简单来说,就是一个分

【测试】输入正确用户名和密码,点击登录没有响应的可能性原因

目录 一、前端问题 1. 界面交互问题 2. 输入数据校验问题 二、网络问题 1. 网络连接中断 2. 代理设置问题 三、后端问题 1. 服务器故障 2. 数据库问题 3. 权限问题: 四、其他问题 1. 缓存问题 2. 第三方服务问题 3. 配置问题 一、前端问题 1. 界面交互问题 登录按钮的点击事件未正确绑定,导致点击后无法触发登录操作。 页面可能存在

业务中14个需要进行A/B测试的时刻[信息图]

在本指南中,我们将全面了解有关 A/B测试 的所有内容。 我们将介绍不同类型的A/B测试,如何有效地规划和启动测试,如何评估测试是否成功,您应该关注哪些指标,多年来我们发现的常见错误等等。 什么是A/B测试? A/B测试(有时称为“分割测试”)是一种实验类型,其中您创建两种或多种内容变体——如登录页面、电子邮件或广告——并将它们显示给不同的受众群体,以查看哪一种效果最好。 本质上,A/B测

客户案例:安全海外中继助力知名家电企业化解海外通邮困境

1、客户背景 广东格兰仕集团有限公司(以下简称“格兰仕”),成立于1978年,是中国家电行业的领军企业之一。作为全球最大的微波炉生产基地,格兰仕拥有多项国际领先的家电制造技术,连续多年位列中国家电出口前列。格兰仕不仅注重业务的全球拓展,更重视业务流程的高效与顺畅,以确保在国际舞台上的竞争力。 2、需求痛点 随着格兰仕全球化战略的深入实施,其海外业务快速增长,电子邮件成为了关键的沟通工具。

安全管理体系化的智慧油站开源了。

AI视频监控平台简介 AI视频监控平台是一款功能强大且简单易用的实时算法视频监控系统。它的愿景是最底层打通各大芯片厂商相互间的壁垒,省去繁琐重复的适配流程,实现芯片、算法、应用的全流程组合,从而大大减少企业级应用约95%的开发成本。用户只需在界面上进行简单的操作,就可以实现全视频的接入及布控。摄像头管理模块用于多种终端设备、智能设备的接入及管理。平台支持包括摄像头等终端感知设备接入,为整个平台提

2024网安周今日开幕,亚信安全亮相30城

2024年国家网络安全宣传周今天在广州拉开帷幕。今年网安周继续以“网络安全为人民,网络安全靠人民”为主题。2024年国家网络安全宣传周涵盖了1场开幕式、1场高峰论坛、5个重要活动、15场分论坛/座谈会/闭门会、6个主题日活动和网络安全“六进”活动。亚信安全出席2024年国家网络安全宣传周开幕式和主论坛,并将通过线下宣讲、创意科普、成果展示等多种形式,让广大民众看得懂、记得住安全知识,同时还

业务协同平台--简介

一、使用场景         1.多个系统统一在业务协同平台定义协同策略,由业务协同平台代替人工完成一系列的单据录入         2.同时业务协同平台将执行任务推送给pda、pad等执行终端,通知各人员、设备进行作业执行         3.作业过程中,可设置完成时间预警、作业节点通知,时刻了解作业进程         4.做完再给你做过程分析,给出优化建议         就问你这一套下