之前发过一个关于用JavaScript验证密码强度的,程序很简洁,只用了一个正则便能验证所有情况,但是因为利用了取巧的方法,所以只能在IE中使用,在FF中失效,现在修改一下做一个兼容的版本。
规则如下(分四个等级,等级超高强度越高):
0. 密码为空
1. 密码长度小于六位.或者密码只有一种组合
2. 密码长度大于五位, 且有两种组合.
3. 密码长度大于五位, 且有三种组合.
4. 密码长度大于五位, 且有四种组合.
四种组合指 数字,小写字母,大写字母,其它字符
源代码如下:
<
script language
=
"
JavaScript
"
>
function
EvaluatePassword(word)

...
{
if (word == "")

...{
return 0;
}
else if (word.length < 6)

...{
return 1;
}
else

...{
return word.match(/[a-z](?![^a-z]*[a-z])|[A-Z](?![^A-Z]*[A-Z])|d(?![^d]*d)|[^a-zA-Zd](?![a-zA-Zd]*[^a-zA-Zd])/g).length;
}
}
var
test
=
new
Array(
""
,
"
a1_
"
,
"
abcdef
"
,
"
abcde123
"
,
"
ads23%
"
,
"
aA1B2^&2
"
);
for
(
var
i
in
test)

...
{
document.write(test[i] + " 的密码强度为" + EvaluatePassword(test[i]) + "<br>");
}
</
script
>
转自:http://www.cnblogs.com/0009/archive/2007/05/08/738888.html