代码审计:云业cms后台注入漏洞复现

代码审计:云业cms后台注入漏洞复现

  • 云业CMS
  • 漏洞寻找
  • 漏洞发现
  • 漏洞利用

云业CMS

云业CMS内容管理系统是由云业信息科技开发的一款专门用于中小企业网站建设的PHP开源CMS,可用来快速建设一个品牌官网(PC,手机,微信都能访问),后台功能强大,安全稳定,操作简单。
源码下载:https://www.mycodes.net/43/10244.htm

昨天发现的前台注入漏洞,拿到几个官方演示站点去测试,失败了,试了其他调用getip()方法的函数,也不行,估计他们修改过这个函数了。
群里大佬说后台还有一处注入可以利用,叫我试试,于是菜鸡的我默默打开了Seay。。。

漏洞寻找

废话不多说,又经过一番寻找与“提示”,发现core/admin/deparment.php文件,其中id值是通过post直接获取的,然后被edit_admin_department()调用。
代码审计:云业cms后台注入漏洞复现_第1张图片
去到edit_admin_department()函数定义处,发现过滤语句。
代码审计:云业cms后台注入漏洞复现_第2张图片
但是仔细一看,发现代码只是过滤了departmentname和olddepartmentname两个变量,放过了我们的id变量,只是判断id值是否为空。

if($departmentname!=$olddepartmentname){
		$num=$this->db->GetCount("select count(*) as total from `#yunyecms_department` where departmentname='$departmentname' and departmentid<>$id limit 1");
		if($num){ messagebox(Lan('department_already_exist'),url_admin('department_add','','',$this->hashurl['usvg']),"warn");	}
}

从代码可以看出,如果departmentname的值不等于olddepartmentname,就执行sql语句,我们的id值没有任何过滤出现在sql语句中,应该有注入无疑了。

漏洞发现

来到core/admin/deparment.php所在的页面,即后台的部门管理处。
代码审计:云业cms后台注入漏洞复现_第3张图片
修改部门名字,只要前后名字不一致即可,使用burp抓包。
代码审计:云业cms后台注入漏洞复现_第4张图片
发送到Repeater模块,构造参数,可以看到sql报错。
代码审计:云业cms后台注入漏洞复现_第5张图片

漏洞利用

不想动手,就扔到sqlmap去跑就完事了。

sqlmap.py -r C:\Users\Administrator\Desktop\yunye.txt --batch

代码审计:云业cms后台注入漏洞复现_第6张图片

你可能感兴趣的:(代码审计)