本文給出了兩個密碼強度的正則表達式方案,一個簡單,一個更復雜和安全。並分別給出了兩個方案的解析和測試程序。通常你們能夠根據本身的項目的實際須要,自行定義本身的密碼正則約定。 javascript
用戶註冊時,都會用到密碼正則校驗。要寫出正確的正則表達式,先要定義表達式規則。java
假設密碼驗證作以下規則定義:正則表達式
根據以上規則,很容易給出正則字面量定義以下:安全
var pattern = /^[\w_-]{6,16}$/;
複製代碼
正則表達式的字面量定義爲包含在一對斜槓(/)之間的字符,例如:測試
var pattern = /s$/;
複製代碼
上述字面量匹配全部以字母「s」結尾的字符串。spa
將字符放進方括號內就組成了字符類。一個字符類能夠匹配它所包含的任意字符。所以,正則表達式/[abc]/
就和字母「a」,「b」,「c」中的任意一個都匹配。3d
字符類可使用連字符來表示字符範圍。要匹配拉丁小寫字母可使用/[a-z]/
。code
字符類 \w
匹配任何ASCII字符組成的單詞,等價於[a-zA-Z0-9]。regexp
[\w_-]
表示匹配任意的拉丁大小寫字母,數字再加上下劃線和減號。cdn
在正則表達式中用{ }來表示元素重複出現的次數。
{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;
複製代碼
從以上測試能夠看出,密碼足夠強壯和安全。你能夠根據項目須要,本身調整上述正則表達式。