标签导航:

密码校验的正则表达式困境与解决方案

许多开发者在进行密码校验时都会遇到一些棘手的问题,例如如何有效地限制密码中连续或重复的字符。本文将针对一个具体的密码校验需求,提供一种基于javascript的解决方案,并详细解释其代码逻辑。

问题描述:需要实现一个密码校验函数,该函数能够验证密码是否包含至少3位数字或字母,并且不允许出现连续或重复的数字或字母(包括正序和倒序),例如“abc.123”、“aaaa@123”、“zyx@321”等是合法的密码,而“abc123”、“12345”、“aaabbb”等则是不合法的密码。单纯使用正则表达式难以实现该校验逻辑,因此需要编写程序代码来完成。

下面提供一个javascript函数checkpassword来解决这个问题:

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

    // 检查密码中是否包含至少3位数字或字母
    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 - 2; i++) {
        if (isDigitOrLetter(password[i]) && isDigitOrLetter(password[i + 1]) && isDigitOrLetter(password[i + 2])) {
            let charCode1 = password.charCodeAt(i);
            let charCode2 = password.charCodeAt(i + 1);
            let charCode3 = password.charCodeAt(i + 2);

            // 检查是否连续
            if (charCode2 === charCode1 + 1 && charCode3 === charCode1 + 2) {
                return false;
            }

            if (charCode2 === charCode1 - 1 && charCode3 === charCode1 - 2) {
                return false;
            }

            // 检查是否重复
            if (password[i] === password[i + 1] && password[i] === password[i + 2]) {
                return false;
            }
        }
    }

    return true;
}

这段代码首先定义了一个辅助函数isdigitorletter,用于判断字符是否为数字或字母。然后,它循环遍历密码字符串,统计数字或字母的个数,如果少于3个,则返回false。接下来,它检查是否存在连续或重复的数字或字母,方法是比较三个相邻字符的ascii码值,以及字符本身是否重复。如果发现连续或重复的字符,则返回false;否则,返回true。 这个函数巧妙地避开了正则表达式的复杂性,通过直接的字符比较实现了更清晰、更易于理解的密码校验逻辑。