我正在尝试编写正则表达式来验证必须符合以下条件的密码:
我尝试了以下但是似乎没有用。
http://jsfiddle.net/many_tentacles/Hzuc9/
<input type='button' value='click' class='buttonClick' />
<input type='text' />
<div></div>
和...
$(".buttonClick").click(function () {
if ($("input[type=text]").filter(function () {
return this.value.match(/^(?=.*[0-9])(?=.*[a-z])(?=.*[A-Z])([a-zA-Z0-9]{8})$/);
})) {
$("div").text("pass");
} else {
$("div").text("fail");
}
});
有什么想法吗?
答案 0 :(得分:159)
您的正则表达式应如下所示:
/^(?=.*\d)(?=.*[a-z])(?=.*[A-Z])[0-9a-zA-Z]{8,}$/
以下是解释:
/^
(?=.*\d) // should contain at least one digit
(?=.*[a-z]) // should contain at least one lower case
(?=.*[A-Z]) // should contain at least one upper case
[a-zA-Z0-9]{8,} // should contain at least 8 from the mentioned characters
$/
答案 1 :(得分:16)
使用单个正则表达式来测试不同的部分比尝试使用单个正则表达式来覆盖所有部分要容易得多。它还可以更轻松地添加或删除验证标准。
另请注意,.filter()
的使用不正确;它将始终返回一个jQuery对象(在JavaScript中被认为是真实的)。就个人而言,我使用.each()
循环迭代所有输入,并报告单个通过/失败状态。如下所示:
$(".buttonClick").click(function () {
$("input[type=text]").each(function () {
var validated = true;
if(this.value.length < 8)
validated = false;
if(!/\d/.test(this.value))
validated = false;
if(!/[a-z]/.test(this.value))
validated = false;
if(!/[A-Z]/.test(this.value))
validated = false;
if(/[^0-9a-zA-Z]/.test(this.value))
validated = false;
$('div').text(validated ? "pass" : "fail");
// use DOM traversal to select the correct div for this input above
});
});
答案 2 :(得分:3)
至少8 = {8,}
:
str.match(/^(?=.*[0-9])(?=.*[a-z])(?=.*[A-Z])([a-zA-Z0-9]{8,})$/)
答案 3 :(得分:2)
你的正则表达式只允许8个字符。使用{8,}
指定八个或更多,而不是{8}
。
但是为什么要限制密码允许的字符范围?我的手机可以在几分钟内强制使用8个字符的字母数字密码。