原文:https://mp.weixin.qq.com/s?__...
微信公众号:毛毛虫的小小蜡笔
CSRF简介
Cross-site request forgery,跨站请求伪造,通常缩写为CSRF或者XSRF。
CSRF之get请求攻击
发起get请求攻击比较简单,只需要通过img标签就可实现。
因为受浏览器同源策略限制,因此不能通过ajax来发起get请求。
Demo验证
代码:
// 这段代码是网站B的页面,只是发起了网站A的请求
// src的值就是网站A下的get请求
csrf之get请求攻击
效果:
用户打开攻击者网站B,则会自动发起网站A的get请求,状态码200表示成功。
如下截图所示:
通过抓包查看,请求是带上了cookie,响应也是正常的。
如下截图所示:
就是如果在别的网站能发起网站A的请求,网站A就是存在CSRF漏洞了。
只是get请求的危害没有post请求那么大,但也不能忽略。
凡是漏洞都要提起十二分精神。
CSRF之post请求攻击
相比get请求的攻击,想发起post请求的攻击,就没那么容易实现。
首先我们知道,在网站B是不能通过ajax发起网站A的post请求的,因为有同源策略限制。
但需要注意的是,同源策略只是限制了XMLHttpRequest和Fetch API,而html的form标签则不受同源策略限制。
同样,get请求的img标签也不受同源策略。
1. 测试form表单发起post请求是否能攻击成功
代码:
// 这段代码是网站B的页面,只是发起了网站A的请求
csrf-post
效果:
结论:
很明显请求是不成功的。
但能把网站A的登录态带过去,也算是成功了一部分。
对比下网站A的post请求,发现两者的请求数据格式不一样。
分析:
form请求的数据格式跟enctype属性有关。
默认的是application/x-www-form-urlencoded,此时就是Form Data。
编码类型总共三种,还有两种是:multipart/form-data和text/plain。
前者是上传文件用的,后者用的比较少。
但正是通过text/plain,可以将数据格式改为Request Payload。
2. 再次验证
代码:
// 在上面的代码的基础上,把form新增enctype属性
csrf-post
效果:
结论:
成功的把数据格式改为Request Payload了,但为啥接口依然报错?
再仔细对比下网站A和网站B的请求,就可以发现:
网站A那边是JSON格式,但网站B这边不是JSON,就是纯文本加换行的一个格式,那这样肯定有问题。
分析:
那有什么好办法解决呢?
只能继续对form表单的参数进行深入挖掘了。
form表单的参数就是input标签等的name和value组成的一些列参数,那可否只用一个input标签,把所有参数都拼接起来?
3. 拼接参数,再次验证
代码:
// 在上面的代码的基础上,把input改为如下所示:
csrf-post
效果:
结论:
攻击成功了。
只要功夫深,还是有点收获的。
最后
- 公众号《毛毛虫的小小蜡笔》
有疑问和问题,请留言。
如果觉得文章还可以,请点赞或收藏,谢谢。