| |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
-> 网络协议 -> 【网络安全渗透】如果你还不懂CSRF?这一篇让你彻底掌握 -> 正文阅读 |
|
[网络协议]【网络安全渗透】如果你还不懂CSRF?这一篇让你彻底掌握 |
01/ 什么是 CSRF面试的时候的著名问题:“谈一谈你对 CSRF 与 SSRF 区别的看法” 这个问题,如果我们用非常通俗的语言讲的话,CSRF 更像是钓鱼的举动,是用户攻击用户的;而对于 SSRF 来说,是由服务器发出请求,用户日服务器的。 CSRF(Cross-site request forgery)跨站请求伪造:攻击者诱导受害者进入第三方网站,在第三方网站中,向被攻击网站发送跨站请求。利用受害者在被攻击网站已经获取的注册凭证,绕过后台的用户验证,达到冒充用户对被攻击的网站执行某项操作的目的。 在 Port 中,原理图是这样的
一个典型的CSRF攻击有着如下的流程:
是不是感觉这个工作流程和 XSS 有些类似,但是 XSS 与 CSRF 的最大区别在于对 Cookie 的使用,XSS 的把受害者 的 Cookie 偷盗过来,而 CSRF 则是借用了受害者的 Cookie。 下面我们举个例子深化一下 CSRF 的原理。
02/ CSRF 实战场景(原理应用)【本段内容摘自美团技术团队文章】 这一天,小明同学百无聊赖地刷着 Gmail 邮件。大部分都是没营养的通知、验证码、聊天记录之类。但有一封邮件引起了小明的注意:
聪明的小明当然知道这种肯定是骗子,但还是抱着好奇的态度点了进去(请勿模仿)。果然,这只是一个什么都没有的空白页面,小明失望的关闭了页面。一切似乎什么都没有发生…… 在这平静的外表之下,黑客的攻击已然得手。小明的 Gmail 中,被偷偷设置了一个过滤规则,这个规则使得所有的邮件都会被自动转发到 hacker@hackermail.com(也就是攻击方的邮箱)。小明还在继续刷着邮件,殊不知他的邮件正在一封封地,如脱缰的野马一般地,持续不断地向着黑客的邮箱转发而去。 不久之后的一天,小明发现自己的域名已经被转让了。懵懂的小明以为是域名到期自己忘了续费,直到有一天,对方开出了 $650 的赎回价码,小明才开始觉得不太对劲。 小明仔细查了下域名的转让,对方是拥有自己的验证码的,而域名的验证码只存在于自己的邮箱里面。小明回想起那天奇怪的链接,打开后重新查看了“空白页”的源码:
代码解析 ———— 这也是我们后续要讲到的 CSRF Poc这个页面只要打开,就会向Gmail发送一个post请求。请求中,执行了“Create Filter”命令,将所有的邮件,转发到“hacker@hackermail.com”。 小明由于刚刚就登陆了Gmail,所以这个请求发送时,携带着小明的登录凭证(Cookie),Gmail的后台接收到请求,验证了确实有小明的登录凭证,于是成功给小明配置了过滤器。 黑客可以查看小明的所有邮件,包括邮件里的域名验证码等隐私信息。拿到验证码之后,黑客就可以要求域名服务商把域名重置给自己。 这个页面只要打开,就会向Gmail发送一个post请求。请求中,执行了“Create Filter”命令,将所有的邮件,转发到“hacker@hackermail.com”。 小明由于刚刚就登陆了Gmail,所以这个请求发送时,携带着小明的登录凭证(Cookie),Gmail的后台接收到请求,验证了确实有小明的登录凭证,于是成功给小明配置了过滤器。 黑客可以查看小明的所有邮件,包括邮件里的域名验证码等隐私信息。拿到验证码之后,黑客就可以要求域名服务商把域名重置给自己。 03/ CSRF 的攻击方式上文中,我们明晰了一下 CSRF 的攻击原理,下面我们主讲漏洞挖掘。 1. GET 请求产生的 CSRFGET 请求产生的 CSRF 较为简单,有 href 攻击的方式与 HTTP 请求的方式。 GET 请求的 href 类 CSRF
在已经登录了 GET 请求的 HTTP 发包 CSRF一般会这样利用:
在受害者访问含有这个img的页面后,浏览器会自动向 2. POST 请求产生的 CSRF
这种类型的 CSRF 利用起来通常使用的是一个自动提交的表单。
访问该页面后,表单会自动提交,相当于模拟用户完成了一次 POST 操作。 POST 类型的攻击通常比 GET 要求更加严格一点,但仍并不复杂。任何个人网站、博客,被黑客上传页面的网站都有可能是发起攻击的来源,后端接口不能将安全寄托在仅允许 POST 上面。 这里可以通过 Burpsuite 自带的 CSRF Poc 工具进行攻击,不过在使用的时候也有一些小技巧。 基础的 CSRF 攻击体验对应可以尝试的靶场,在这靶场当中,并没有添加任意的 CSRF 防御 因为 CSRF 本质上是一种钓鱼,所以我们也需要第三方网站攻击,如自己的服务器,或者 Burpsuite 靶场自带的 Exploit server;WebGoat 的 WebWolf。 我们先登录进靶场当中,发现有一功能点 ———— Update email 试想一下,我们账号进行了 Update email 的操作。 若我们在自己的服务器上面挂上恶意的 Payload,诱导他人点击之后。相对应的,对方的邮箱也会变成我们 CSRF Poc 所指定的,这样子一来,我就可以通过 “忘记密码” 这种服务来获取他账户的权限了。(当然这里有个前提,对方是登录过的且 Cookie 处于生效期间) Exploit 部分 用 Burpsuite 自带的 CSRF Poc 构造出基本框架; 然后我们把这个核心的表单拿出来,并加以修改,构造成最后的 POC
再放入到 Exploit Server 当中,点击 Deliver it to victim 即可。 在对方未对 CSRF 进行任何防御的时候,上述两种 CSRF 攻击方式能够通杀。
04/ CSRF 的防御手段主流的 CSRF 防御手段有以下两种 ban 掉不明域外访问 ———— 使用同源检测与 Samesite Cookie 多加一层验证手段 CSRF Token 1. 接近无敌的防御手法 CSRF Token如果通俗易懂地解释一下 CSRF Token 的工作原理的话是这样的。 CSRF Token 每随着页面被操作,Token 都会改变,比如 f5 刷新,点击按钮等等,都会导致 CSRF Token 变化。 而每一个请求的 CSRF Token 会通过后端代码验证 Token 的有效性 ———— 是否正确,在时间戳上是否有效,如果加密字符串一致且时间未过期,那么这个Token就是有效的。 以 Java 为例,我们介绍一下 CSRF Token 服务端的校验逻辑
2. 用的较少的限制同源Samesite 是 Set-Cookie 的一种属性,它有三个值
还有一种属性为
这种方法的原理也比较简单,因为 CSRF 的本质也是钓鱼,比如我通过邮箱发送钓鱼邮件,那么这时候的 “源” 就是邮箱界面。 如果服务器设置了严格的同源政策,将不接收来自邮箱这一 “源” 的请求。 ok,讲完了常规的防御手段,接下来我们聊聊绕过 05/ 针对 CSRF Token 与同源政策的绕过手段
若非特别提醒,以下所有靶场的业务点均处于 **“Update email”**下。 1. 将 POST 修改为 GET 请求进行绕过
背后逻辑: CSRF Token 在 POST 请求当中生效,且业务点并非完全限制请求为 POST 请求,从而给了攻击者进行绕过的机会。 探测方法:将 CSRF Token 删掉,并将 HTTP 请求修改为 GET 请求。 此时的回显为 回显 302,代表我们可以用这种方式进行绕过,构造 Payload 2. 删除 CSRF Token 进行绕过
背后逻辑: 并没有强验证 CSRF Token 的存在性。 我们尝试删除 CSRF Token,回显 302 在删除掉 CSRF Token 之后生成 POC 即可。 3. CSRF Token 未与用户 Session 绑定背后逻辑 未进行严格的一一身份对应,这其实很好理解。举个例子,我们登录注册界面,实际上是需要去匹配用户名与密码是否相等的,而这里的逻辑也是一致。 那么这里,我可以先修改 Cookie,再修改 CSRF Token,来观察 CSRF Token 与 Cookie 是否对应了,或者说是否绑定了。 修改 Cookie 中的 Session 值,观察回显为 “Unauthorized” 修改 CSRF Token,观察回显为 “Invalid CSRF Token” 说明 CSRF Token 并未与 session 绑定,而是与 csrfKey(也就是 value) 绑定的,根据 cookie 的传递性,我们可以在其他页面提前把 csrfKey 注入进去,这里我们利用 这里借用梨子师傅的 Poc 当受害者点击 CSRF 链接时会先触发 CLRF 注入 Set-Cookie 参数值,将 csrfKey 值添加到 Cookie 中,然后再用附有与 csrfKey 对应的 CSRF Token 的请求去提交修改邮箱请求。 4. 当 Cookie 中的 CSRF 值与 CSRF Token 的值一致时背后逻辑: 只是将 CSRF Token 简单复制到 cookie 头中,然后仅验证两者是否一致。 所以这里我们的绕过 Poc 的核心部分应该是这样的,
5. 对不严格的 Referer 限制进行绕过背后逻辑 并没有特别严格地限制 Referer,仅仅只是不允许了这一种的 Referer。
一般我们通过 若
靶场部分,同样是对更改邮箱这个功能点进行 CSRF 攻击 这里我们需要介绍一下 我们先修改 Referer 为 baidu.com 查看回显,成功发包。 修改 Referer 为 构造 Payload,将 06/ 小结CSRF 攻击本质上还是一种钓鱼手段,本文着重讲了一些 CSRF 攻击的绕过手法,说不定渗透的时候多试一试就能起到意想不到的效果。 |
|
网络协议 最新文章 |
使用Easyswoole 搭建简单的Websoket服务 |
常见的数据通信方式有哪些? |
Openssl 1024bit RSA算法---公私钥获取和处 |
HTTPS协议的密钥交换流程 |
《小白WEB安全入门》03. 漏洞篇 |
HttpRunner4.x 安装与使用 |
2021-07-04 |
手写RPC学习笔记 |
K8S高可用版本部署 |
mySQL计算IP地址范围 |
|
上一篇文章 查看所有文章 |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 | -2025/1/19 7:06:25- |
|
网站联系: qq:121756557 email:121756557@qq.com IT数码 |