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
。 这种方法比使用正则表达式更直观,也更容易理解和维护。