LMXCMS代码审计
下载地址:
大家自己找,,,,,,,,,,,,,ahhhhhhhh
data:image/s3,"s3://crabby-images/2d465/2d46564ab99b771ba366c77a376c64f568de4560" alt=""
审计版本:
注意看图V1.2data:image/s3,"s3://crabby-images/50ae6/50ae63dbd33f9dce8ce5427c4308db377ba94682" alt=""
安装步骤:
- 放在环境的www目录下,修改数据库配置文件用户名密码
- 按照提示下一步下一步即ok
data:image/s3,"s3://crabby-images/71ad3/71ad30a981c7c66e8bec133b268e9856b2ff2af4" alt=""
插曲
如果在xdebug的过程中,还没有完成过程就返回500的报错,需要设置修改一下配置文件
data:image/s3,"s3://crabby-images/ec32d/ec32db6bdd7ceaceb325c74327c707e60f680477" alt=""
选择xdebug的站点的配置文件添加
这里的配置应该是设置的超时时间是600s,单位为S(秒)
data:image/s3,"s3://crabby-images/e50b6/e50b6ccbe325dc24676fa2d84e79b38c8565ea5d" alt=""
重启服务器即ok
审源码
废话不多说,直接审源码该cms就是MVC架构,但是比较奇怪的是这个MVC写的有点不太规范,,,,,尤其这命名,对不是搞开发的同志们来说比较难受😫,,,,前端来讲功能太简单了,查询以及留言,直接看后台,后台的功能比较多,结合管理员的控制层看源码,,,,
源码结构如下:
data:image/s3,"s3://crabby-images/f3351/f33517741dcd54f404e1549cb3019de1ab9ccc21" alt=""
如果说想要直接了当的去分析,去找漏洞,怎么找?命令执行漏洞?得分析路由,传参以及执行函数,文件上传,那么直接找上传点,文件包含直接找文件包含的函数,注入漏洞呢,还是找sql语句,那么逻辑漏洞呢,没什么好的方式,估计黑盒的效果都要比白盒方便,未授权也差不多个意思了,,,,
顺便“水”一下
怎么设置debug呢,,,,差不多过程就是下面的了,反正是我一直是这么审的,除此之外,我发现一个问题,很多小伙伴都比较喜欢代码审计工具,工具只是起到辅助效果,个人觉得审计的魅力不就是在debug么,,,,,,
data:image/s3,"s3://crabby-images/cee8b/cee8b21c2ce8dc300528e88dcdb87abb11b38b87" alt=""
php环境配置
路径
File->Settings-> Languages&Frameworks->PHP
data:image/s3,"s3://crabby-images/be8de/be8decd93b0c3f05d8ce3a79d20ade1028eb7992" alt=""
安装xdebug扩展
根据php版本选择扩展文件
php-5.6-xdebug
放在对应的php文件夹执行程序的ext文件夹内
data:image/s3,"s3://crabby-images/63285/63285ec201aa7d5326a17b2943dea740f89e9566" alt=""
接着修改php.ini配置文件,添加xdebug配置内容
[XDebug]
xdebug.profiler_output_dir="D:\phpStudy\tmp\xdebug"
xdebug.trace_output_dir="D:\phpStudy\tmp\xdebug"
;zend_extension="D:\phpStudy\php\php-5.6.27-nts\ext\php_xdebug.dll"
;zend_extension="C:\phpStudy20161103\php\php-5.6.27-nts\ext\php_xdebug.dll"
zend_extension="D:\phpStudy\php\php-5.6.27-nts\ext\php_xdebug-2.5.5-5.6-vc11-nts-x86_64.dll" ;指定Xdebug扩展文件的绝对路径
xdebug.auto_trace=on ;启用代码自动跟踪
xdebug.collect_params=on ;允许收集传递给函数的参数变量
xdebug.collect_return=on ;允许收集函数调用的返回值
xdebug.trace_output_dir="D:\phpStudy\tmp\xdebug" ;指定堆栈跟踪文件的存放目录
xdebug.profiler_enable=on ;是否启用Xdebug的性能分析,并创建性能信息文件
xdebug.profiler_output_dir="D:\phpStudy\tmp\xdebug" ;指定性能分析信息文件的输出目录
xdebug.remote_enable = on ;是否开启远程调试
xdebug.remote_handler = dbgp ;指定远程调试的处理协议
xdebug.remote_host= localhost ;指定远程调试的主机名
xdebug.remote_port = 9000 ;指定远程调试的端口号
xdebug.idekey = PHPSTORM ;指定传递给DBGp调试器处理程序的IDE Key
在这里尽量根据访问该xdebug网址去识别对应的xdebug,否则无法启动debug,或者选用路径为对应php版本下的xdebug
data:image/s3,"s3://crabby-images/2701f/2701f6e0dd8b7e02f610f3100fe4bc61cdec3c04" alt=""
验证xdebug安装成功
data:image/s3,"s3://crabby-images/e6faa/e6faa3f7fd8bba88bf33a4f3d015749b2dbe6e2a" alt=""
phpstrom配置debug环境
data:image/s3,"s3://crabby-images/3ebef/3ebefe5b201646f677bc7197c0a87c31b3580c6b" alt=""
配置server
data:image/s3,"s3://crabby-images/1bce1/1bce1252547ef39af60be59a217ecb39e27a73d7" alt=""
运行时选择配置的servers
data:image/s3,"s3://crabby-images/4831c/4831c4ea395e22843980f85a24b52805d7246556" alt=""
浏览器安装插件方便使用进行debug测试
data:image/s3,"s3://crabby-images/06b42/06b4247f1394b642f9416e3cb8a7280555a81a5b" alt=""
审源码继续
根据源码结构继续进行,前端功能比较简单,能测试的点比较少,注入,XSS,其它的也没啥了,直接看后台吧(并不是说前台没有问题),前端真的是有漏洞的,,,,主要后台功能点比较多,值得分析一下。
直接瞅一瞅看一看比较容易出现问题的地方
至于为什么看这里,看截图应该不用解释,sql注入常见的问题点
data:image/s3,"s3://crabby-images/ae8a6/ae8a610a8825ce6627cb86b80347b0459d42b32f" alt=""
基本上关于数据库的类文件也都在这个位置,那么不考虑sql语句在查询过程中的路由,直接看这里的sql语句的话那么问题已经来了,如果能直接实现闭合的话是就可以实现注入了,增删改查的所有语句也都在这里,
那么直接寻找查询的位置进行测试,纵观后台功能,查询点开始测试,追踪路由,后台功能页
data:image/s3,"s3://crabby-images/4d9ff/4d9fffc9bcd41ffdfeb807e8aa706fd88662d01c" alt=""
c/admin/BookAction.class.php
因为直接调试函数跟进调用的就是上面的函数语句了,下断点调试
data:image/s3,"s3://crabby-images/1893e/1893ea4ba2d96fdfa5bc672b5fd4e88b7e18de33" alt=""
猜测没有问题,并且测试的时候发现,有报错
data:image/s3,"s3://crabby-images/86487/864871e7e9860e73401a9d443a74510c0ce7d4d7" alt=""
那么构造构造报错语句payload即可
id=11 and updatexml(1,concat(1,user()),1) #
或者
id=11 and (extractvalue(1, concat(0x5c,user()))) #
报错语句的两种语法,,,,
okk,注入存在
data:image/s3,"s3://crabby-images/ae327/ae3274811708c4e3d54355956d2003cd168c8994" alt=""
接下来,大家自己发挥,送0day的时候到了,ahhhh
简单翻一翻功能,其实最直接了当的就是上传点了,就比较离谱
data:image/s3,"s3://crabby-images/faaa2/faaa293d76a80265771883f71f56f3d03a92d2d3" alt=""
webshell不必多说了,就比较奇怪的就是这个上传的点的按钮点击没啥反应,可能版本的问题吧,自个花卉
源码的上传以及文件类型的检测是这样的
data:image/s3,"s3://crabby-images/6bcac/6bcac1d476b8124ceeb891b4d646e66935991b4a" alt=""
在upload.class.php中对上传单个文件多个文件进行了控制,上传成功命名做了设定,
data:image/s3,"s3://crabby-images/91e60/91e6053fa247cc606226f2ba1a41aa6325d1a2a3" alt=""
在check方法中也只是对文件类型做了简单的校验,所以文件上传这块儿也是比较好利用拿shell的,,,,
后端多个地方明显存在XSS漏洞,简单测试一下,顺便追踪一下路由
data:image/s3,"s3://crabby-images/cbfcf/cbfcf85d9245584fad31f808382f8baf46e43378" alt=""
效果
data:image/s3,"s3://crabby-images/376c3/376c39da5cfc6e98caeae283d95fcd1055358689" alt=""
存储型XSS一枚,,,,追踪分析如下
data:image/s3,"s3://crabby-images/efd75/efd75f6efecbadab8af463c1e432b7e0cf7dfc2d" alt=""
确定漏洞位置,定位控制层
修改广告时,传入的参数为13个。POST传入的数据,在修改的时候调了function update方法, 同时调用了check方法对传入的数据进行过滤检测
data:image/s3,"s3://crabby-images/3f85b/3f85bcfb0817b809760d87d7b0aa900804e55f2b" alt=""
验证文字数据的时候正则太过简单,对于remarks值来说,也就是备注没有对数据做任何的处理,所以也就造成了XSS漏洞的形成,类似的位置很多,,,,可做扩展。
结语
审计还是得靠分析和验证或者思路吧,大佬请绕路,不当之处还请各位师傅指正。