【原文连接】https://www.lovesec.com/penetration-test/233.htmlhtml
证码缺乏时间限制仅值判断了验证码是
够正确未判断验证码是否过时算法
码输入验证码完成验证
-案例
输入目标手机号,获取验证码随意输入验证码1234点击下一步,拦截数据包sql
POST /Account/CheckYQCode HTTP/1.1 Host: www.xxxx.cn User-Agent: Mozilla/5.0 (Windows NT 6.1; WOW64; rv:47.0) Gecko/20100101 Firefox/47.0 Accept: */* Accept-Language: zh-CN,zh;q=0.8,en-US;q=0.5,en;q=0.3 Accept-Encoding: gzip, deflate, br Content-Type: application/x-www-form-urlencoded; charset=UTF-8 X-Requested-With: XMLHttpRequest http://www.xxxx.cn/userCenter/toForgetPsdPage.html?mobile= Content-Length: 11 Cookie: ASP.NET_SessionId=30jfruwn22h2xng3ahhzo2jx Connection: close YQCode=1234
获得正确的验证码是1059而后到网站上输入验证码跳转到输入新密码的页面完成重置密码cookie
点击获取验证码app
1269,输入验证
码跳转到重置页面less
首先使用本身的手机号接收验证码而后输入本身手机号接收到的验证码,点击下一步并拦截数据包最后替换数据包里的目标手机号,而后发包工具
这个案例也是验证码未绑定用户延伸一下,有时候测试会碰到这种,咱们发现用户名被加密了,咱们又没法得知加密算法,怎么办?大部分这种都不须要知道加密算法,好比这个例子,获得的liuyy的加密后的值是80e688602c4b11e66320c421e3b71ef2,那么咱们就能够直接用这个keycode了测试
步骤是同样的,输入咱们的用户名和收到的验证码,而后把咱们的keycode替换为liuyy的那个keycode,这样就能够重置liuyy的密码了。(漏洞缘由仍是是判断了验证码是否正确,而没有判断该验证码是否跟该用户匹配。)网站
点击找回密码,首先咱们输入zhangwei,而后点击获取验证码,这个时候把手机号改成咱们本身的号码,输入咱们本身的号码和验证码,成功跳到重置密码的页面,密码重置成功加密
输入手机号13888888888,输入验证码123456,验证码错误的时候,返回包返回的是0
这里咱们所作的就是把0修改成1,能够借工具修改返回包,咱们把0改成1,而后查看页面,成功跳转到修改密码的页面,输入新密码便可修改用户13888888888的密码
使用帐户wangshuai,点击获取验证码,而后补齐下面的连接https://xxx/page/login/veifyAccess.html?username=wangshuai&email=wangshuai@xxx.com.cn,访问后便可直接重置该用户的密码
点击当即提交,获得右边的数据包,测试发现修改id为5,就能够把对应的用户密码修改成123456,没有对用户的原始密码判断,也没有判断id是否属于该用户。8.修改密码处id可替换
成功修改id为5的用户密码为123456,并且能够经过遍历id修改全部用户的密码
到第一步去获取验证码的时候,点击下一页,能够获取到该用户wangshuai对应的内容Cookie: JSESSIONID=E1AC27A7302C03C9432DE2254B99311A
view-source:https://www.xxx.com/ua/employee/forUpdate.do查看下这个页面的源代码,找到了一个参数loginId,这个参数是对应用户身份的而咱们发现 上面的数据包里没有这个参数,那么咱们是否能够本身添加上去呢?
添加字段loginId,而且把值修改成他人的用户,发包返回修改为功这样咱们就成功的把用户871XXXXXX的密码改成了跟咱们密码相同的值