溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

如何使用正則表達式校驗密碼強度

發(fā)布時間:2021-09-09 15:06:39 來源:億速云 閱讀:300 作者:小新 欄目:互聯(lián)網(wǎng)科技

這篇文章主要介紹了如何使用正則表達式校驗密碼強度,具有一定借鑒價值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。

前言

用戶注冊時,都會用到密碼正則校驗。要寫出正確的正則表達式,先要定義表達式規(guī)則。

方案1 (簡單)

假設密碼驗證做如下規(guī)則定義:

  • 最短6位,最長16位 {6,16}

  • 可以包含小寫大母 [a-z] 和大寫字母 [A-Z]

  • 可以包含數(shù)字 [0-9]

  • 可以包含下劃線 [ _ ] 和減號 [ - ]

根據(jù)以上規(guī)則,很容易給出正則字面量定義如下:

var pattern = /^[\w_-]{6,16}$/;

方案1分析

字面量 / /

正則表達式的字面量定義為包含在一對斜杠(/)之間的字符,例如:

var pattern = /s$/;

上述字面量匹配所有以字母“s”結尾的字符串。

字符類 [ ]

將字符放進方括號內(nèi)就組成了字符類。一個字符類可以匹配它所包含的任意字符。因此,正則表達式 /[abc]/ 就和字母“a”,“b”,“c”中的任意一個都匹配。

字符類可以使用連字符來表示字符范圍。要匹配拉丁小寫字母可以使用 /[a-z]/ 。

字符類 \w

字符類 \w 匹配任何ASCII字符組成的單詞,等價于[a-zA-Z0-9]。

[\w_-] 表示匹配任意的拉丁大小寫字母,數(shù)字再加上下劃線和減號。

重復 {}

在正則表達式中用{ }來表示元素重復出現(xiàn)的次數(shù)。

  • {n,m} 匹配前一項至少n次,但不能超過m次

  • {n,} 匹配前一項n次或更多次

  • {n} 匹配前一項n次


[\w_-]{6,16} 表示匹配任意的拉丁大小寫字母,數(shù)字再加上下劃線和減號出現(xiàn)最少6次,最多16次。

匹配位置

^ 匹配字符串的開頭,在多行檢索中,匹配一行的開頭
$ 匹配字符串的結尾,在多行檢索中,匹配一行的結尾
/^\w/ 匹配以大小寫字母或數(shù)字開頭的字符串。

方案1測試

給出測試結果如下:

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ù)測試結果可以看出,方案1只是對密碼做了簡單的限定,不能保證密碼的強度和帳號安全。

方案2 (安全)

假設密碼驗證做如下規(guī)則定義:

  • 最短6位,最長16位 {6,16}

  • 必須包含1個數(shù)字

  • 必須包含2個小寫字母

  • 必須包含2個大寫字母

  • 必須包含1個特殊字符

根據(jù)以上規(guī)則,很容易給出正則字面量定義如下:

var pattern = /^.*(?=.{6,16})(?=.*\d)(?=.*[A-Z]{2,})(?=.*[a-z]{2,})(?=.*[!@#$%^&*?\(\)]).*$/;

方案2分析

字符類 .

字符類 . 表示除換行符和其他Unicode行終止符之外的任意字符。

正向先行斷言 (?= )

在符號“(?=” 和 “)” 之間加入一個表達式,它就是一個先行斷言,用以說明圓括號內(nèi)的表達式必須正確匹配。比如: /Java(?=\:)/ 只能匹配Java且后面有冒號的。

(?=.*[!@#$%^&*?\(\)])

該先行斷言表示,必須包括一個特殊字符。上述表達式中的10個特殊字符為鍵盤1,2...0的上檔鍵字符,也可以添加別的特殊字符。注意:如果添加字符是正則表達式中具有特殊含義的,需要在符號前加反斜線(\)轉義。

方案2測試

給出測試結果如下:

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;

感謝你能夠認真閱讀完這篇文章,希望小編分享的“如何使用正則表達式校驗密碼強度”這篇文章對大家有幫助,同時也希望大家多多支持億速云,關注億速云行業(yè)資訊頻道,更多相關知識等著你來學習!

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權內(nèi)容。

AI