本文給出了兩個密碼強度的正則表達式方案,一個簡單,一個更復(fù)雜和安全。并分別給出了兩個方案的解析和測試程序。一般大家可以根據(jù)自己的項目的實際需要,自行定義自己的密碼正則約定。
前言
用戶注冊時,都會用到密碼正則校驗。要寫出正確的正則表達式,先要定義表達式規(guī)則。
方案1 (簡單)
假設(shè)密碼驗證做如下規(guī)則定義:
根據(jù)以上規(guī)則,很容易給出正則字面量定義如下:
var pattern = /^[/w_-]{6,16}$/;方案1分析
字面量 / /
正則表達式的字面量定義為包含在一對斜杠(/)之間的字符,例如:
var pattern = /s$/;
上述字面量匹配所有以字母“s”結(jié)尾的字符串。
字符類 [ ]
將字符放進方括號內(nèi)就組成了字符類。一個字符類可以匹配它所包含的任意字符。因此,正則表達式 /[abc]/ 就和字母“a”,“b”,“c”中的任意一個都匹配。
字符類可以使用連字符來表示字符范圍。要匹配拉丁小寫字母可以使用 /[a-z]/ 。
字符類 /w
字符類 /w 匹配任何ASCII字符組成的單詞,等價于[a-zA-Z0-9]。
[/w_-] 表示匹配任意的拉丁大小寫字母,數(shù)字再加上下劃線和減號。
重復(fù) {}
在正則表達式中用{ }來表示元素重復(fù)出現(xiàn)的次數(shù)。
[/w_-]{6,16} 表示匹配任意的拉丁大小寫字母,數(shù)字再加上下劃線和減號出現(xiàn)最少6次,最多16次。
匹配位置
^ 匹配字符串的開頭,在多行檢索中,匹配一行的開頭
$ 匹配字符串的結(jié)尾,在多行檢索中,匹配一行的結(jié)尾
/^/w/ 匹配以大小寫字母或數(shù)字開頭的字符串。
方案1測試
給出測試結(jié)果如下:
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;根據(jù)測試結(jié)果可以看出,方案1只是對密碼做了簡單的限定,不能保證密碼的強度和帳號安全。
方案2 (安全)
假設(shè)密碼驗證做如下規(guī)則定義:
根據(jù)以上規(guī)則,很容易給出正則字面量定義如下:
var pattern = /^.*(?=.{6,16})(?=.*/d)(?=.*[A-Z]{2,})(?=.*[a-z]{2,})(?=.*[!@#$%^&*?/(/)]).*$/;方案2分析
字符類 .
字符類 . 表示除換行符和其他Unicode行終止符之外的任意字符。
正向先行斷言 (?= )
在符號“(?=” 和 “)” 之間加入一個表達式,它就是一個先行斷言,用以說明圓括號內(nèi)的表達式必須正確匹配。比如: /Java(?=/:)/ 只能匹配Java且后面有冒號的。
(?=.*[!@#$%^&*?/(/)])
該先行斷言表示,必須包括一個特殊字符。上述表達式中的10個特殊字符為鍵盤1,2...0的上檔鍵字符,也可以添加別的特殊字符。注意:如果添加字符是正則表達式中具有特殊含義的,需要在符號前加反斜線(/)轉(zhuǎn)義。
方案2測試
給出測試結(jié)果如下:
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;總結(jié)
以上所述是小編給大家介紹的密碼強度的正則表達式兩種方案JS總結(jié)篇,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對武林網(wǎng)網(wǎng)站的支持!
新聞熱點
疑難解答
圖片精選