代码审计-youdiancms最新版getshell漏洞

代码审计-youdiancms最新版getshell漏洞

前言

在近期的授权项目中,遇到了一个目标,使用了youdiancms,需要获取权限,进而进行审计,本次代码审计过程先发现SQL注入漏洞,继续审计发现getshell的漏洞,本文将本次审计过程书写下来,仅作为学习研究,请勿用作非法用途。

0x01 未授权SQL注入

首先拿到源码一看,发现该系统是基于THINKPHP3开发的。

App/Lib/Action/HomeBaseAction.class.php:16

image-20210514153103940

cookie可控,然后赋值给了$this->_fromUser

跟踪一下$this->_fromUser的引用。

App/Lib/Action/Home/ChannelAction.class.php:732

image-20210514152830011

这里将$this->_fromUser带入到了hasVoted函数中,跟进该函数:

image-20210514152908218

很明显,TP3的where注入。

延时注入payload如下:

  1. GET /index.php/Channel/voteAdd HTTP/1.1
  2. Host: localhost
  3. Content-Length: 2
  4. Accept: application/json, text/javascript, */*; q=0.01
  5. X-Requested-With: XMLHttpRequest
  6. Accept-Encoding: gzip, deflate
  7. Accept-Language: zh-CN,zh;q=0.9,en;q=0.8
  8. Cookie: youdianfu[0]=exp;youdianfu[1]==(select 1 from(select sleep(3))a)
  9. Connection: close

0x02 绕过登录到getshell过程

0x0201 流程思路

  1. 验证码处可以设置任意session
  2. 碰撞md5让AdminGroupID==1(超级管理员)
  3. 后台修改模板插入phpcode实现代码执行

0x0x202 任意session设置

App/Lib/Action/BaseAction.class.php:223

img

这个函数挺有意思的,本来是个生成验证码的操作,但是没想到所有的参数都是用户可以控制的,特别是这个$verifyName还可控。跟进buildImageVerify看看如何设置的session

img

红框处设置了session,并且session的键名我们是可控的,但是值不可控,是个md5值。

然后我们去看看管理员的校验函数。在App/Lib/Action/AdminBaseAction.class.php:7

img

起作用的就两个函数,isLogincheckPurview。跟进第一个看看:

img

这个函数很简单,就简单的判断session是否存在,我们可以通过上文的验证码函数来设置。

然后就是checkPurview函数。

img

这里判断了AdminGroupID的值,当等于1的时候就是超级管理员,由于这里是个弱类型比较。所以上文设置session中的md5是可以碰撞的。

编写脚本得到超级管理员的session了,然后登录。

img

0x0203 后台getshell

后台模板管理,可以修改模板,但是对<?php有检测,如图所示:

img

我们可以用<?=?>来绕过这个检测。

如图所示:

img

访问首页即可触发:

img

注:zc.cn为本地127.0.0.1的地址,并非zc.cn的域名

  • 发表于 2021-05-14 16:00:08
  • 阅读 ( 9979 )
  • 分类:漏洞分析

0 条评论

中铁13层打工人
中铁13层打工人

79 篇文章

站长统计