美文网首页
密码修改逻辑漏洞-前端验证

密码修改逻辑漏洞-前端验证

作者: vampire_hunter | 来源:发表于2019-03-20 11:03 被阅读0次

今天上线测试发现了一个只有前端验证的修改密码逻辑漏洞,但是该应用根本没有对验证码进行验证。
访问测试地址http://xxx.xxx.xxx.xxx:xxx/dss,查看页面功能,发现存在找回密码功能。

登陆页面
点击找回密码功能,输入内容后发现前端验证,未向后端发送数据包
找回密码
从验证码入手,看看发送验证码的情况
获取验证码
发现点击发送没有时间限制,但是不能指定电话号码,所以不知道是否真的有短信发送
点击确定,向服务器发起获取验证码请求
POST /dss/findPwd.e HTTP/1.1
Host: xxx.xxx.xxx.xxx:xxx
User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:65.0) Gecko/20100101 Firefox/65.0
Accept: */*
Accept-Language: zh-CN,zh;q=0.8,zh-TW;q=0.7,zh-HK;q=0.5,en-US;q=0.3,en;q=0.2
Accept-Encoding: gzip, deflate
Referer: http://xxx.xxx.xxx.xxx:xxx/dss/findPwd.jsp
Content-Type: application/x-www-form-urlencoded; charset=UTF-8
X-Requested-With: XMLHttpRequest
Content-Length: 7
Connection: close
Cookie: JSESSIONID=14CEE8646A9BF274394F948BE24D5ED5
id=test

放过请求找回test账号,返回200,没有数据内容


正确用户名返回数据包

再尝试请求一个错误的账号,返回内容中疑似存在验证码,但是该验证码不能成功重置密码


错误用户名返回数据包
上面数据包根据返回内容不同,也可用来爆破存在的用户名
既然是前端验证,我们通过使用开发者工具箱找到前端验证的函数
更新密码调用的js函数

查看找到的函数内容

            function checkform() {
                $("#checkResult").html('');
                var checkResultMes = '请输入的用户账号!';
                var findPwdNumber = $('#findPwdNumber').val();
                if(!findPwdNumber||$.trim(findPwdNumber)=='') {   
                //验证手机号为11位
                     $("#checkResult").html(checkResultMes);
                     return false;
                }
                return true;
            }
            
            //验证输入的手机号是否存在
            function getRand(){
                if(checkform()){
                    var findPwdNumber = $('#findPwdNumber').val();
                    if(confirm('是否确认执行找回工号[' + findPwdNumber + ']的密码操作?')){                        
                        $.post('/dss/findPwd.e',{id:findPwdNumber},function(data){
                            var result = eval(data);
                            $("#findPwdRand_hidden").val(result[0].findPwdRand);
                            $("#checkResult").html(result[0].Msg);
                        });
                    }
                }
            }
            
            //重置密码
            function forwordcxc(){
                var info = {};
                info.findPwdNumber = $("#findPwdNumber").val();
                info.findPwdRand = $("#findPwdRand").val();
                info.findPwdRand_hidden = $("#findPwdRand_hidden").val();
                info.findPwdNew = $("#findPwdNew").val();
                info.findPwdNewRepeat = $("#findPwdNewRepeat").val();
                if(info.findPwdNew==""||info.findPwdNewRepeat==""){
                    $("#checkResult").html('请输入两次新密码!');
                    return;
                }
                if(info.findPwdNew != info.findPwdNewRepeat){
                    $("#checkResult").html('两次输入的密码不一致,请重新输入!');
                    return;
                }
                var numExp = new RegExp(/([0-9])/);
                var strExp = new RegExp(/([a-zA-Z])/);
                var strnumExp = new RegExp(/([!,@,#,$,%,^,&,*,?,_,~])/);
                if(!(strnumExp.test(info.findPwdNew)&& strExp.test(info.findPwdNew)&&numExp.test(info.findPwdNew)&&info.findPwdNew.length>=8)){
                    $("#checkResult").html('新密码必需包括特殊字符(! @ # $ % ^ & * ? _ ~), 字母, 数字且长度大于7!');
                    return;
                }
                if(info.findPwdRand==""){
                    $("#checkResult").html('请输入接收到的验证码!');
                    return;
                }
                if(info.findPwdRand != info.findPwdRand_hidden){
                    $("#checkResult").html('验证码输入错误,请重新输入!');
                    return;
                }
                info.findPwdNew = aesEncrypt(info.findPwdNew);
                info.findPwdNewRepeat = aesEncrypt(info.findPwdNewRepeat);
                $.post('/dss/updatePwd.e',info,function(data){
                    var value = eval(data);
                    if(value[0].result == '1'){
                        $("#checkResult").html("密码更新成功,此页面3秒后关闭,请用新密码登录!");
                        setTimeout(rollBack, 3000);
                    }else{
                        $("#checkResult").html("修改密码错误,请联系管理员!");
                    }
                });
            }
            
            function rollBack(){
                window.location.href = "/dss/index.jsp";
            }

查看js代码发现验证码是否正确只通过提交字段和隐藏字段是否相等


验证码验证代码

使用开发者工具箱的控制台执行js代码


执行js代码
获取id为findPwdRand和findPwdRand_hidden的值,发现findPwdRand_hidden内容为空,为findPwdRand_hidden赋值与findPwdRand相同的值,点击更新密码,然后发起修改请求
修改密码数据包

放过拦截的数据包


修改成功

密码更新成功,验证可登陆。

相关文章

  • 密码修改逻辑漏洞-前端验证

    今天上线测试发现了一个只有前端验证的修改密码逻辑漏洞,但是该应用根本没有对验证码进行验证。访问测试地址http:/...

  • 越权/逻辑漏洞

    一.本文介绍 1、本文介绍平行越权、垂直越权;登录、注册、修改密码、密码找回、支付等地方是否存在逻辑漏洞。 二.学...

  • 逻辑漏洞挖掘

    逻辑漏洞介绍 逻辑漏洞就是指攻击者利用业务的设计缺陷、获取敏感信息或者破坏业务的完整性。一般出现在密码修改、越权访...

  • 参考的文章

    验证码 图片验证码前端怎样获取后端生成的验证码图片,并且点击图片的时候改变验证码 记住密码 前端记住密码功能密码安...

  • 密码重置姿势

    修改密码的验证码返回到Web前端进行验证,也就是点击获取验证码后,验证码返回到网页的某个hidden属性的标签中....

  • 短信验证

    很多应用中注册、修改密码等均用到短信验证,一般实际开发中短信验证功能的开发,前端会调用后台给的获取验证码和提交验证...

  • Django2.0在线教育网站开发(二)user应用view完善

    本篇笔记记录站首页显示,发送接收验证码,用户注册,登录,密码找回,修改密码等问题 一、网站前端页面配置 1.进入t...

  • 逻辑漏洞

    原文链接:http://wyb0.com/posts/logical-loophole/ 逻辑漏洞 密码找回漏洞 ...

  • Xcode 测试工具 UI Tests

    背景: 最近做个会员登入系统,前端验证账号密码、修改密码、注册会员等一系列输入框的数据格式是否符合预期,每次都需要...

  • 中国北斗与GPS车辆管理与监控系统系统官网登录设计缺陷密码可绕过

    描述 验证处存在缺陷,密码处理不当。 存在万能密码 漏洞证明 网站IP地址:http://61.167.103.2...

网友评论

      本文标题:密码修改逻辑漏洞-前端验证

      本文链接:https://www.haomeiwen.com/subject/ynvamqtx.html