⼀次对五指 cms的任意⽂件删除漏洞挖掘
2022-9-13 14:15:40 Author: 白帽子(查看原文) 阅读量:12 收藏

声明

由于传播、利用此文所提供的信息而造成的任何直接或者间接的后果及损失,均由使用者本人负责,雷神众测以及文章作者不为此承担任何责任。

雷神众测拥有对此文章的修改和解释权。如欲转载或传播此文章,必须保证此文章的完整性,包括版权声明等全部内容。未经雷神众测允许,不得任意修改或者增减此文章内容,不得以任何方式将其用于商业目的。

No.1

前言

五指cms由国内专业的⽹站内容管理系统提供商北京五指互联科技有限公司开发,是⼀款开源的内容管理系统,使⽤php5+mysql开发,但是在2017年就停⽌了维护,之前也披露过不少漏洞,接下来就开启挖洞之旅。

No.2

过程

跟进了⼏个⽂件后我们来到了coreframe/app/attachment/admin/index.php:

/**     * 目录列表方式查看     *     * @author tuzwu     * @createtime 2014-8-1 13:14:29     * @modifytime     * @param     * @return array     */    public function dir(){        $dir = isset($GLOBALS['dir']) && trim($GLOBALS['dir']) ? str_replace(array('..\\', '../', './', '.\\'), '', trim($GLOBALS['dir'])) : '';        $dir = str_ireplace(array('%2F', '//'), '/', $dir);        $lists = glob(ATTACHMENT_ROOT . $dir . '/' . '*');        if (!empty($lists)) rsort($lists);        $cur_dir = str_replace(array(WWW_ROOT, DIRECTORY_SEPARATOR . DIRECTORY_SEPARATOR), array('', DIRECTORY_SEPARATOR), ATTACHMENT_ROOT . $dir . '/');        include $this->template('dir', M);    }

在调用str_replace()函数对dir参数的输入进行过滤时,会将'..\', '../', './', '.\'直接过滤掉,我们这里直接输入"..",目录直接溢出:

光溢出没什么危害啊,也不能下载或者访问,但是WUZHI CMS后台为了方便自带删除的功能,但是只能删除这一级目录的文件吗?带着疑问继续跟进,我们再看
coreframe/app/attachment/admin/index.php的另一处:

/**     * 删除文件     *     * @author tuzwu     * @createtime     * @modifytime     * @param     * @return     */    public function del(){        $id = isset($GLOBALS['id']) ? $GLOBALS['id'] : '';        $url = isset($GLOBALS['url']) ? remove_xss($GLOBALS['url']) : '';        if (!$id && !$url) MSG(L('operation_failure'), HTTP_REFERER, 3000);        if ($id) {          if(!is_array($id)) {        $ids = array($id);      } else {        $ids = $id;      }    foreach($ids as $id) {      $where = array('id' => $id);      $att_info = $this->db->get_one('attachment', $where, 'usertimes,path');      if ($att_info['usertimes'] > 1) {        $this->db->update('attachment', 'usertimes = usertimes-1', $where);      }      else {        $this->my_unlink(ATTACHMENT_ROOT . $att_info['path']);        $this->db->delete('attachment', $where);        $this->db->delete('attachment_tag_index', array('att_id'=>$id));      }    }    MSG(L('delete success'), HTTP_REFERER, 1000);    }    else {        if (!$url) MSG('url del ' . L('operation_failure'), HTTP_REFERER, 3000);        $path = str_ireplace(ATTACHMENT_URL, '', $url);        if ($path) {            $where = array('path' => $path);            $att_info = $this->db->get_one('attachment', $where, 'usertimes,id');
if (empty($att_info)) { $this->my_unlink(ATTACHMENT_ROOT . $path); MSG(L('operation_success'), HTTP_REFERER, 3000); }
if ($att_info['usertimes'] > 1) { $this->db->update('attachment', 'usertimes = usertimes-1', array('id' => $att_info['id'])); } else { $this->my_unlink(ATTACHMENT_ROOT . $path); $this->db->delete('attachment', array('id' => $att_info['id'])); MSG(L('operation_success'), HTTP_REFERER, 3000); } } else { MSG(L('operation_failure'), HTTP_REFERER, 3000); } }}

对url参数的输入貌似没有做任何控制,首先我们先删除robots.txt

然后我们在url参数这里发现果然没有限制,可以任意文件删除。

招聘启事

安恒雷神众测SRC运营(实习生)
————————
【职责描述】
1.  负责SRC的微博、微信公众号等线上新媒体的运营工作,保持用户活跃度,提高站点访问量;
2.  负责白帽子提交漏洞的漏洞审核、Rank评级、漏洞修复处理等相关沟通工作,促进审核人员与白帽子之间友好协作沟通;
3.  参与策划、组织和落实针对白帽子的线下活动,如沙龙、发布会、技术交流论坛等;
4.  积极参与雷神众测的品牌推广工作,协助技术人员输出优质的技术文章;
5.  积极参与公司媒体、行业内相关媒体及其他市场资源的工作沟通工作。

【任职要求】 
 1.  责任心强,性格活泼,具备良好的人际交往能力;
 2.  对网络安全感兴趣,对行业有基本了解;
 3.  良好的文案写作能力和活动组织协调能力。

简历投递至 

[email protected]

设计师(实习生)

————————

【职位描述】
负责设计公司日常宣传图片、软文等与设计相关工作,负责产品品牌设计。

【职位要求】
1、从事平面设计相关工作1年以上,熟悉印刷工艺;具有敏锐的观察力及审美能力,及优异的创意设计能力;有 VI 设计、广告设计、画册设计等专长;
2、有良好的美术功底,审美能力和创意,色彩感强;精通photoshop/illustrator/coreldrew/等设计制作软件;
3、有品牌传播、产品设计或新媒体视觉工作经历;

【关于岗位的其他信息】
企业名称:杭州安恒信息技术股份有限公司
办公地点:杭州市滨江区安恒大厦19楼
学历要求:本科及以上
工作年限:1年及以上,条件优秀者可放宽

简历投递至 

[email protected]

安全招聘
————————

公司:安恒信息
岗位:Web安全 安全研究员
部门:战略支援部
薪资:13-30K
工作年限:1年+
工作地点:杭州(总部)、广州、成都、上海、北京

工作环境:一座大厦,健身场所,医师,帅哥,美女,高级食堂…

【岗位职责】
1.定期面向部门、全公司技术分享;
2.前沿攻防技术研究、跟踪国内外安全领域的安全动态、漏洞披露并落地沉淀;
3.负责完成部门渗透测试、红蓝对抗业务;
4.负责自动化平台建设
5.负责针对常见WAF产品规则进行测试并落地bypass方案

【岗位要求】
1.至少1年安全领域工作经验;
2.熟悉HTTP协议相关技术
3.拥有大型产品、CMS、厂商漏洞挖掘案例;
4.熟练掌握php、java、asp.net代码审计基础(一种或多种)
5.精通Web Fuzz模糊测试漏洞挖掘技术
6.精通OWASP TOP 10安全漏洞原理并熟悉漏洞利用方法
7.有过独立分析漏洞的经验,熟悉各种Web调试技巧
8.熟悉常见编程语言中的至少一种(Asp.net、Python、php、java)

【加分项】
1.具备良好的英语文档阅读能力;
2.曾参加过技术沙龙担任嘉宾进行技术分享;
3.具有CISSP、CISA、CSSLP、ISO27001、ITIL、PMP、COBIT、Security+、CISP、OSCP等安全相关资质者;
4.具有大型SRC漏洞提交经验、获得年度表彰、大型CTF夺得名次者;
5.开发过安全相关的开源项目;
6.具备良好的人际沟通、协调能力、分析和解决问题的能力者优先;
7.个人技术博客;
8.在优质社区投稿过文章;

岗位:安全红队武器自动化工程师
薪资:13-30K
工作年限:2年+
工作地点:杭州(总部)

【岗位职责】
1.负责红蓝对抗中的武器化落地与研究;
2.平台化建设;
3.安全研究落地。

【岗位要求】
1.熟练使用Python、java、c/c++等至少一门语言作为主要开发语言;
2.熟练使用Django、flask 等常用web开发框架、以及熟练使用mysql、mongoDB、redis等数据存储方案;
3:熟悉域安全以及内网横向渗透、常见web等漏洞原理;
4.对安全技术有浓厚的兴趣及热情,有主观研究和学习的动力;
5.具备正向价值观、良好的团队协作能力和较强的问题解决能力,善于沟通、乐于分享。

【加分项】
1.有高并发tcp服务、分布式等相关经验者优先;
2.在github上有开源安全产品优先;
3:有过安全开发经验、独自分析过相关开源安全工具、以及参与开发过相关后渗透框架等优先;
4.在freebuf、安全客、先知等安全平台分享过相关技术文章优先;
5.具备良好的英语文档阅读能力。

简历投递至 

[email protected]

专注渗透测试技术

全球最新网络攻击技术

END


文章来源: http://mp.weixin.qq.com/s?__biz=MzAwMDQwNTE5MA==&mid=2650246342&idx=1&sn=c976f3eb9348d525441bec3c3f7e03a0&chksm=82ea576fb59dde795f6e04c48ada361fc01221c8dca97d776e52b467648d721e3bca9f4f8a43#rd
如有侵权请联系:admin#unsafe.sh