本文给出了两个密码强度的正则表达式方案,一个简单,一个更复杂和安全。并分别给出了两个方案的解析和测试程序。通常你们能够根据本身的项目的实际须要,自行定义本身的密码正则约定。
javascript
用户注册时,都会用到密码正则校验。要写出正确的正则表达式,先要定义表达式规则。java
假设密码验证作以下规则定义:正则表达式
根据以上规则,很容易给出正则字面量定义以下:安全
var pattern = /^[\w_-]{6,16}$/;
正则表达式的字面量定义为包含在一对斜杠(/)之间的字符,例如:测试
var pattern = /s$/;
上述字面量匹配全部以字母“s”结尾的字符串。code
将字符放进方括号内就组成了字符类。一个字符类能够匹配它所包含的任意字符。所以,正则表达式/[abc]/
就和字母“a”,“b”,“c”中的任意一个都匹配。ip
字符类可使用连字符来表示字符范围。要匹配拉丁小写字母可使用/[a-z]/
。字符串
字符类 \w
匹配任何ASCII字符组成的单词,等价于[a-zA-Z0-9]。get
[\w_-]
表示匹配任意的拉丁大小写字母,数字再加上下划线和减号。源码
在正则表达式中用{ }来表示元素重复出现的次数。
{n,m}
匹配前一项至少n次,但不能超过m次{n,}
匹配前一项n次或更屡次{n}
匹配前一项n次[\w_-]{6,16}
表示匹配任意的拉丁大小写字母,数字再加上下划线和减号出现最少6次,最多16次。
/^\w/
匹配以大小写字母或数字开头的字符串。
给出测试结果以下:
var pattern = /^[\w_-]{6,16}$/; pattern.test('123456') = true; pattern.test('-ifat33') = true; pattern.test('42du') = false; pattern.test('du42du42du42du421') = false; pattern.test('42du42@') = false;
根据测试结果能够看出,方案1只是对密码作了简单的限定,不能保证密码的强度和账号安全。
假设密码验证作以下规则定义:
根据以上规则,很容易给出正则字面量定义以下:
var pattern = /^.*(?=.{6,16})(?=.*\d)(?=.*[A-Z]{2,})(?=.*[a-z]{2,})(?=.*[!@#$%^&*?\(\)]).*$/;
字符类 . 表示除换行符和其余Unicode行终止符以外的任意字符。
(?= )
在符号“(?=” 和 “)” 之间加入一个表达式,它就是一个先行断言,用以说明圆括号内的表达式必须正确匹配。好比:/Java(?=\:)/
只能匹配Java且后面有冒号的。
(?=.*[!@#$%^&*?\(\)])
该先行断言表示,必须包括一个特殊字符。上述表达式中的10个特殊字符为键盘1,2...0的上档键字符,也能够添加别的特殊字符。注意:若是添加字符是正则表达式中具备特殊含义的,须要在符号前加反斜线()转义。
给出测试结果以下:
var pattern = /^.*(?=.{6,16})(?=.*\d)(?=.*[A-Z]{2,})(?=.*[a-z]{2,})(?=.*[!@#$%^&*?\(\)]).*$/; pattern.test('du42DU!') = true; pattern.test('duDUd!') = false; pattern.test('42dud!') = false; pattern.test('42DUD!') = false; pattern.test('42duDU') = false; pattern.test('42duU(') = false; pattern.test('42dUU!') = false;
从以上测试能够看出,密码足够强壮和安全。你能够根据项目须要,本身调整上述正则表达式。