密码强度函数只返回一个值



我是Javascript的新手,我正在尝试编写一个密码强度函数。但每次我输入密码时,它只返回一个值("非常强")。我完全弄糊涂了!!这是我的代码:

function pwd_Validation()
    {
        var strength = new Array();
        strength[0] = "Blank";
        strength[1] = "Very Weak";
        strength[2] = "Weak";
        strength[3] = "Medium";
        strength[4] = "Strong";
        strength[5] = "Very Strong";

        var password = document.getElementById('pwd')
        if (password.length < 1)
            var score = 1;

       else if (password.length < 4)
             score = 2

        else if (password.length >= 8 && password.value.match(/[a-z]/))
                 score = 3;

       else if (password.length >= 8 && password.value.match(/[a-z]/) && password.value.match(/[A-Z]/) && password.value.match(/[0-9]/))
                score = 4;

       else  (password.length >= 8 && password.value.match(/[a-z]/) && password.value.match(/[A-Z]/) && password.value.match(/[0-9]/) && password.value.match(/.[!,@,#,$,%,^,&,*,?,_,~,-,£,(,)]/))
                score = 5;

        document.getElementById('spnPwd').innerHTML = strength[score];
        if ( password.value = "")
            document.getElementById('spnPwd').innerHTML = strength[0];
            document.getElementById('spnPwd').style.color="#FF0000"
        if ( strength[score] == 1)
            document.getElementById('spnPwd').innerHTML = strength[1];
            document.getElementById('spnPwd').style.color="#FF0000"
        if ( strength[score] == 3)
            document.getElementById('spnPwd').innerHTML = strength[3];
            document.getElementById('spnPwd').style.color="#FFCC00"
        if ( strength[score] == 4)
            document.getElementById('spnPwd').innerHTML = strength[4];
            document.getElementById('spnPwd').style.color="#19D119"
         if ( strength[score] == 5)
            document.getElementById('spnPwd').innerHTML = strength[5];
            document.getElementById('spnPwd').style.color="#006600"
    }

HTML代码:

Password :   <input type="password" id="pwd" onblur="pwd_Validation()" />
                <span id="spnPwd" class="pwd_Strength" ></span><br />

有几个编码错误和逻辑错误。我建议进行以下修复/改进的重写:

  1. 获取实际的密码值并使用其长度,而不是使用password DOM元素的长度
  2. 处理长度在4到7之间的情况(逻辑跳过的情况)
  3. 按正确的顺序排列regex测试,以便它实际找到正确的分数
  4. 更正了标点符号regex
  5. 修复else逻辑问题
  6. 将颜色放入一个平行数组中
  7. 以更高效/紧凑的方式声明强度字符串
  8. 给你的分数一个默认值,这样它就保证有一个值
  9. 不要多次重复regex测试
  10. 使用regex.test是因为当你只想知道它是否匹配时,它比regex.match更高效
  11. 从数组中提取所需的颜色值,而不是为每个分数提取if语句
  12. 只获取spnPwd DOM元素一次
  13. 将数字正则表达式更改为d
  14. 为了安全起见,在所有if/else语句上使用大括号

以及建议的代码:

function pwd_Validation() {
    var strengths = ["Blank", "Very Weak", "Weak", "Medium", "Strong", "Very Strong"];
    var colors = ["#FF0000", "#FF0000", "#FFCC00", "#FFCC00", "#19D119", "#006600"];
    var score = 0;
    var regLower = /[a-z]/, regUpper = /[A-Z]/, regNumber = /d/, regPunctuation = /[.,!@#$%^&*?_~-£()]/;
    var password = document.getElementById('pwd').value;
    if (!password) {
        score = 0;
    } else if (password.length < 2) {
        score = 1;
    } else if (password.length < 4) {
        score = 2;
    } else if (password.length <= 7) {
        score = 3;
    } else {
        // length is >= 8 in here
        if (regLower.test(password) && regUpper.test(password) && regNumber.test(password)) {
            // if it also has punctuation, then it gets a 5, otherwise just a 4
            if (regPunctuation.test(password)) {
                score = 5;
            } else {
                score = 4;
            }
        } else {
            // if doesn't have upper, lower and numbers, then it gets a 3
            score = 3;
        }
    }
    var spanPwd = document.getElementById('spnPwd');
    spanPwd.innerHTML = strengths[score];
    spanPwd.style.color = colors[score];
}

上一个else中缺少if,因此解析如下:

...
else {
    (password.length >= 8 && password.value.match(/[a-z]/) && password.value.match(/[A-Z]/) && password.value.match(/[0-9]/) && password.value.match(/.[!,@,#,$,%,^,&,*,?,_,~,-,£,(,)]/))
}
score = 5;

在控制结构中总是使用括号是一个好习惯。

您忘记将密码字段转换为其值:

var password = document.getElementById('pwd')

应该是var password=document.getElementById('pwd').value

在最初的情况下,password.length是未定义的,所有与它的比较结果都为false。(因此执行最后的else

此外,您的最后一个else

   else  (password.length >= 8 && password.value.match(/[a-z]/) && password.value.match(/[A-Z]/) && password.value.match(/[0-9]/) && password.value.match(/.[!,@,#,$,%,^,&,*,?,_,~,-,£,(,)]/))
            score = 5;

应该是

   else  if(password.length >= 8 && password.value.match(/[a-z]/) && password.value.match(/[A-Z]/) && password.value.match(/[0-9]/) && password.value.match(/.[!,@,#,$,%,^,&,*,?,_,~,-,£,(,)]/))
            score = 5;

除此之外,请在你的if中使用括号。有这样的代码是不好的做法:

if(...)
 ...
else if(...)
 ...
else
 ...

这更好:

if(...){
 ...
}else if(...){
 ...
}else{
 ...
}

保存到var分数,然后询问strength[score]if (strength[score] == 3)

那么您在代码的第二部分中缺少了一些{}!

在最后一部分中,您可以使用

switch(score) {
 case 1: ... break;
...
 default: ... break;
}

我已经通过jsbeautizer.org推送了您的代码。这根据javascript解释器实际运行代码的方式对您的代码进行了重新调整。请注意,if语句是如何而不是运行您认为的代码的。

function pwd_Validation() {
    var strength = new Array();
    strength[0] = "Blank";
    strength[1] = "Very Weak";
    strength[2] = "Weak";
    strength[3] = "Medium";
    strength[4] = "Strong";
    strength[5] = "Very Strong";
    var password = document.getElementById('pwd')
    if (password.length < 1) var score = 1;
    else if (password.length < 4) score = 2
    else if (password.length >= 8 && password.value.match(/[a-z]/)) score = 3;
    else if (password.length >= 8 && password.value.match(/[a-z]/) && password.value.match(/[A-Z]/) && password.value.match(/[0-9]/)) score = 4;
    else(password.length >= 8 && password.value.match(/[a-z]/) && password.value.match(/[A-Z]/) && password.value.match(/[0-9]/) && password.value.match(/.[!,@,#,$,%,^,&,*,?,_,~,-,£,(,)]/))
    score = 5;
    document.getElementById('spnPwd').innerHTML = strength[score];
    if (password.value = "") document.getElementById('spnPwd').innerHTML = strength[0];
    document.getElementById('spnPwd').style.color = "#FF0000"
    if (strength[score] == 1) document.getElementById('spnPwd').innerHTML = strength[1];
    document.getElementById('spnPwd').style.color = "#FF0000"
    if (strength[score] == 3) document.getElementById('spnPwd').innerHTML = strength[3];
    document.getElementById('spnPwd').style.color = "#FFCC00"
    if (strength[score] == 4) document.getElementById('spnPwd').innerHTML = strength[4];
    document.getElementById('spnPwd').style.color = "#19D119"
    if (strength[score] == 5) document.getElementById('spnPwd').innerHTML = strength[5];
    document.getElementById('spnPwd').style.color = "#006600"    
}

举几个特别的例子:

if (strength[score] == 5) document.getElementById('spnPwd').innerHTML = strength[5];
document.getElementById('spnPwd').style.color = "#006600"    

你可能打算这样做:

if (strength[score] == 5) {
    document.getElementById('spnPwd').innerHTML = strength[5];
    document.getElementById('spnPwd').style.color = "#006600"
}

还有:

else(password.length >= 8 && password.value.match(/[a-z]/) && password.value.match(/[A-Z]/) && password.value.match(/[0-9]/) && password.value.match(/.[!,@,#,$,%,^,&,*,?,_,~,-,£,(,)]/))
score = 5;

你的意思可能是:

else if (password.length >= 8 && password.value.match(/[a-z]/) && password.value.match(/[A-Z]/) && password.value.match(/[0-9]/) && password.value.match(/.[!,@,#,$,%,^,&,*,?,_,~,-,£,(,)]/)) {
    score = 5;
}

你在代码中提到的实际问题是因为我去掉了第二个条件。行score = 5而不是任何条件的一部分,并且将始终运行(由于上述原因)。这就是为什么你总是看到密码是"非常强"的原因。

相关内容

  • 没有找到相关文章

最新更新