【技术干货】CVE-2022-25237 Bonitasoft Platform RCE漏洞分析

渗透技巧 2年前 (2022) admin
428 0 0
【技术干货】CVE-2022-25237 Bonitasoft Platform RCE漏洞分析
【技术干货】CVE-2022-25237 Bonitasoft Platform RCE漏洞分析
【技术干货】CVE-2022-25237 Bonitasoft Platform RCE漏洞分析
xxhzz
@PortalLab实验室

项目介绍

Bonitasoft 是一个业务自动化平台,可以更轻松地在业务流程中构建、部署和管理自动化应用程序;Bonita 是一个用于业务流程自动化和优化的开源和可扩展平台。

漏洞描述

在Bonitasoft Authorization漏洞版本,由于 API 授权过滤器中配置问题,通过精心构造的的字符串附加到 API URL,能够绕过权限认证。拥有普通用户权限的攻击者在绕过权限认证后,将恶意代码部署到服务器上,进行远程代码执行。

利用范围

For community(社区版):

2022.1-u0 (7.14.0) 以下

For subscription(订阅版):

2022.1-u0 (7.14.0) 以下

2021.2-u4 (7.13.4) 以下

2021.1-0307 (7.12.11) 以下

7.11.7 以下

漏洞分析

环境搭建

使用docker搭建环境,docker镜像(https://hub.docker.com/_/bonita/tags)选择7.13.0版本。
【技术干货】CVE-2022-25237 Bonitasoft Platform RCE漏洞分析
下载镜像之后,直接输入命令docker run -d -p 8080:8080 -p 5050:5050,5050为远程动态调试端口。

在/opt/bonita目录下载源码。

【技术干货】CVE-2022-25237 Bonitasoft Platform RCE漏洞分析
使用idea进行远程调试配置。
【技术干货】CVE-2022-25237 Bonitasoft Platform RCE漏洞分析

在/opt/bonita/BonitaCommunity-2021.2-u0/server/bin/catalina.sh中加入配置。

【技术干货】CVE-2022-25237 Bonitasoft Platform RCE漏洞分析

随即访问http://ip:8080,环境搭建成功。

【技术干货】CVE-2022-25237 Bonitasoft Platform RCE漏洞分析

默认账号密码:install/install

代码调试

从漏洞披露参考文章看,该漏洞产生的原理是由于身份验证/权限绕过,导致没有特权的用户可以通过api端口上传恶意文件,从而命令执行。

【技术干货】CVE-2022-25237 Bonitasoft Platform RCE漏洞分析
定位到参考文章所提交到的filers
在bonitaBonitaCommunity-2021.2-u0serverwebappsbonitaWEB-INFweb.xml配置文件中,自定义了filter,并且对参数excludePatterns进行了赋值。
【技术干货】CVE-2022-25237 Bonitasoft Platform RCE漏洞分析

2个不同的过滤器类RestAPIAuthorizationFilter、TokenValidatorFilter中的参数excludePattern都被指定为“i18ntranslation”

【技术干货】CVE-2022-25237 Bonitasoft Platform RCE漏洞分析
【技术干货】CVE-2022-25237 Bonitasoft Platform RCE漏洞分析
在web.xml的192行和215行定义了/API/*路由下对应的filter为RestAPIAuthorizationFilter、TokenValidatorFilter
而RestAPIAuthorizationFilter和TokenValidatorFilter都属于AbstractAuthorizationFilter子类。
【技术干货】CVE-2022-25237 Bonitasoft Platform RCE漏洞分析
【技术干货】CVE-2022-25237 Bonitasoft Platform RCE漏洞分析
定位到org.bonitasoft.console.common.server.login.filter.AbstractAuthorizationFilter#doFilter函数。
【技术干货】CVE-2022-25237 Bonitasoft Platform RCE漏洞分析
会使用“sessionIsNotNeeded”函数进行检查,如果它返回 true,它将继续应用程序流程。
而sessionIsNotNeeded 函数检查匹配 URL 中的是否包含excludePatterns
在web.xml已经对excludePatterns进行了赋值为“i18ntranslation”,所以当url中包含“i18ntranslation”时,isMatched 就会返回true
【技术干货】CVE-2022-25237 Bonitasoft Platform RCE漏洞分析

流程就会继续,就相当于绕过了权限过滤,允许访问资源。

【技术干货】CVE-2022-25237 Bonitasoft Platform RCE漏洞分析

总结就是在URl包含“/i18ntranslation/../”或“;i18ntranslation”就可以绕过权限认证。

为实现远程命令执行,思路是上传恶意文件,上传接口在web.xml中也定义了,为/API/pageUpload

【技术干货】CVE-2022-25237 Bonitasoft Platform RCE漏洞分析
找到org.bonitasoft.console.common.server.servlet.PageUploadServlet#getPagePermissions
在文件处理过程中,需要获取的session存在apisession
【技术干货】CVE-2022-25237 Bonitasoft Platform RCE漏洞分析
【技术干货】CVE-2022-25237 Bonitasoft Platform RCE漏洞分析

而且未登录的情况下,apisession也没法赋值,就会导致getPagePermissions抛出异常。

所以,为实现远程命令执行,还需要拥有一个普通的用户。

漏洞复现

先创建一个test/test用户。
【技术干货】CVE-2022-25237 Bonitasoft Platform RCE漏洞分析
根据以上分析原理,使用exp,成功执行命令。
【技术干货】CVE-2022-25237 Bonitasoft Platform RCE漏洞分析

修复建议

更新至安全无漏洞版本。

参考材料

1.https://rhinosecuritylabs.com/application-security/cve-2022-25237-bonitasoft-authorization-bypass/

2.https://hub.docker.com/_/bonita


关于Portal Lab

星阑科技 Portal Lab 致力于前沿安全技术研究及能力工具化。主要研究方向为API 安全、应用安全、攻防对抗等领域。实验室成员研究成果曾发表于BlackHat、HITB、BlueHat、KCon、XCon等国内外知名安全会议,并多次发布开源安全工具。未来,Portal Lab将继续以开放创新的态度积极投入各类安全技术研究,持续为安全社区及企业级客户提供高质量技术输出。


【技术干货】CVE-2022-25237 Bonitasoft Platform RCE漏洞分析

原文始发于微信公众号(星阑实验室):【技术干货】CVE-2022-25237 Bonitasoft Platform RCE漏洞分析

版权声明:admin 发表于 2022年10月13日 上午10:41。
转载请注明:【技术干货】CVE-2022-25237 Bonitasoft Platform RCE漏洞分析 | CTF导航

相关文章

暂无评论

您必须登录才能参与评论!
立即登录
暂无评论...