首页 > 文章列表 > 如何用JavaScript高效校验密码复杂度,避免连续或重复字符?

如何用JavaScript高效校验密码复杂度,避免连续或重复字符?

456 2025-04-15

如何用JavaScript高效校验密码复杂度,避免连续或重复字符?

JavaScript密码复杂度校验:高效避免连续或重复字符

密码安全校验是保障系统安全的重要环节,通常需要验证密码的复杂度,例如包含数字、字母,并避免连续或重复字符。单纯依靠正则表达式难以实现这种复杂的校验逻辑。本文针对“密码至少包含三位数字或字母,且不允许出现连续或重复数字或字母(正序和倒序)”这一场景,提供一个JavaScript函数解决方案。

正则表达式在处理此类复杂校验时显得力不从心,因为要排除所有连续或重复序列需要极其复杂的表达式,甚至无法实现。因此,本文采用JavaScript函数的方式,提供更清晰、易维护和可扩展的解决方案。

以下是一个名为checkPassword的JavaScript函数,它接收密码字符串作为输入,返回布尔值表示密码是否满足要求:

function checkPassword(password) {
    const isDigitOrLetter = (char) => /[a-zA-Z0-9]/.test(char);

    // 至少包含三个数字或字母
    let digitOrLetterCount = 0;
    for (let i = 0; i < password.length; i++) {
        if (isDigitOrLetter(password[i])) {
            digitOrLetterCount++;
        }
    }
    if (digitOrLetterCount < 3) return false;

    // 检查连续或重复字符
    for (let i = 0; i < password.length - 1; i++) {
        if (password[i] === password[i + 1] || 
            (i < password.length - 2 && password[i] === password[i + 2])) { //检查连续三个重复
            return false;
        }
    }

    return true;
}

该函数首先统计密码中数字或字母的个数,若少于3个则直接返回false。然后,它遍历密码字符串,检查是否存在连续或重复的字符(包括连续三个)。如果发现任何连续或重复字符,则返回false;否则,返回true。 这种方法比使用正则表达式更直观,也更容易理解和维护。

来源:1740890664