《密码强度校验正则.docx》由会员分享,可在线阅读,更多相关《密码强度校验正则.docx(4页珍藏版)》请在优知文库上搜索。
1、密码强度校验正则密码强度校验正则是一种验证窗码强度的方法。用户注册时,都会用到密码正则校验。要写出正确的正则表达式,先要定义表达式规则。方案1(简单)假设密码验证做如下规则定义:最短6位,最长16位6,16可以包含小写大母a-z和大写字母A-Z可以包含数字0-9可以包含下划线_和减号根据以上规则,很容易给出正则字面量定义如下:varpattern=/Aw_-6,16$/;方案1分析字面量/正则表达式的字面量定义为包含在一对斜杠(/)之间的字符,例如:varpattern=/s$/;上述字面量匹配所有以字母S结尾的字符串。字符类将字符放进方括号内就组成了字符类。一个字符类可以匹配它所包含的任意字
2、符。因此,正则表达式/abc/就和字母“a”,b”,“c”中的任意一个都匹配。字符类可以使用连字符来表示字符范围。要匹配拉丁小写字母可以使用/a-zo字符类w字符类w匹配任何ASCll字符组成的单词,等价于a-zA-ZO-9。w表示匹配任意的拉丁大小写字母,数字再加上下划线和减号。重复在正则表达式中用来表示元素重复出现的次数。n,m匹配前一项至少n次,但不能超过m次n,匹配前一项n次或更多次n匹配前一项n次w.-6,16表示匹配任意的拉丁大小写字母,数字再加上下划线和减号出现最少6次,最多16次。匹配位置匹配字符串的开头,在多行检索中,匹配一行的开头$匹配字符串的结尾,在多行检索中,匹配一行的
3、结尾w匹配以大小写字母或数字开头的字符串。方案1测试给出测试结果如下:varpattern=w-616$/;pattern.test(,123456)=true;pattern,test(-ifat33)=true;pattem.test(42du)=falsejpattern.test(,d42du42du42du421)=falsejpattern.test(42du42(g,)=伯Ise;查看源码根据测试结果可以看出,方案1只是对密码做了简单的限定,不能保证密码的强度和帐号安全。方案2(安全)假设密码验证做如下规则定义:最短6位,最长16位6,16必须包含1个数字必须包含2个小写字母必须
4、包含2个大写字母必须包含1个特殊字符根据以上规则,很容易给出正则字面量定义如下:varpattern=/A/(?=X6,16)(?=.*d)(?=.*A-Z2,)(?=.*a-z2,)(?=.*!#$%A&*?().*$/;方案2分析字符类.字符类.表示除换行符和其他UniCode行终止符之外的任意字符。正向先行断言(?=)在符号(?二和)”之间加入一个表达式,它就是一个先行断言,用以说明圆括号内的表达式必须正确匹配。比如:/Java(?=:)/只能匹配JaVa且后面有冒号的。(?=.*!#$%A&*?()该先行断言表示,必须包括一个特殊字符。上述表达式中的10个特殊字符为键盘1,2.0的上档
5、键字符,也可以添加别的特殊字符。注意:如果添加字符是正则表达式中具有特殊含义的,需要在符号前加反斜线()转义。方案2测试给出测试结果如下:varpattern=/A.*(?=.6,16)(?=.*d)(?=.*A-Z2,)(?=.*a-z2,)(?=.*!#$%A&*?().*$/;Pattern.test(du42DU!)=true;Pattern.test(duDUd!)=false;pattern.test(42dud!)=false;pattern.test(142DUD!)=false;Pattern.test(42duDU)=false;pattem.test(42dull()=false;pattern.test(42dUU!)=false;查看源码从以上测试可以看出,密码足够强壮和安全。你可以根据项目需要,自己调整上述正则表达式。