主頁(yè) > 知識(shí)庫(kù) > 密碼強(qiáng)度的正則表達(dá)式兩種方案JS總結(jié)篇

密碼強(qiáng)度的正則表達(dá)式兩種方案JS總結(jié)篇

熱門(mén)標(biāo)簽:西藏智能外呼系統(tǒng)代理商 地圖標(biāo)注教學(xué)點(diǎn) 400電話(huà)辦理電話(huà)辦理 貴港公司如何申請(qǐng)400電話(huà) 梅縣地圖標(biāo)注 ai電話(huà)機(jī)器人搭建 外呼系統(tǒng)無(wú)呼出路由是什么原因 呼叫系統(tǒng)外呼只能兩次 甘肅醫(yī)療外呼系統(tǒng)排名

本文給出了兩個(gè)密碼強(qiáng)度的正則表達(dá)式方案,一個(gè)簡(jiǎn)單,一個(gè)更復(fù)雜和安全。并分別給出了兩個(gè)方案的解析和測(cè)試程序。一般大家可以根據(jù)自己的項(xiàng)目的實(shí)際需要,自行定義自己的密碼正則約定。

 

前言

用戶(hù)注冊(cè)時(shí),都會(huì)用到密碼正則校驗(yàn)。要寫(xiě)出正確的正則表達(dá)式,先要定義表達(dá)式規(guī)則。

方案1 (簡(jiǎn)單)

假設(shè)密碼驗(yàn)證做如下規(guī)則定義:

  • 最短6位,最長(zhǎng)16位 {6,16}
  • 可以包含小寫(xiě)大母 [a-z] 和大寫(xiě)字母 [A-Z]
  • 可以包含數(shù)字 [0-9]
  • 可以包含下劃線(xiàn) [ _ ] 和減號(hào) [ - ]

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

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

方案1分析

字面量 / /

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

var pattern = /s$/;

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

字符類(lèi) [ ]

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

字符類(lèi)可以使用連字符來(lái)表示字符范圍。要匹配拉丁小寫(xiě)字母可以使用 /[a-z]/ 。

字符類(lèi) \w

字符類(lèi) \w 匹配任何ASCII字符組成的單詞,等價(jià)于[a-zA-Z0-9]。

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

重復(fù) {}

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

  • {n,m} 匹配前一項(xiàng)至少n次,但不能超過(guò)m次
  • {n,} 匹配前一項(xiàng)n次或更多次
  • {n} 匹配前一項(xiàng)n次

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

匹配位置

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

方案1測(cè)試

給出測(cè)試結(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ù)測(cè)試結(jié)果可以看出,方案1只是對(duì)密碼做了簡(jiǎn)單的限定,不能保證密碼的強(qiáng)度和帳號(hào)安全。

方案2 (安全)

假設(shè)密碼驗(yàn)證做如下規(guī)則定義:

  • 最短6位,最長(zhǎng)16位 {6,16}
  • 必須包含1個(gè)數(shù)字
  • 必須包含2個(gè)小寫(xiě)字母
  • 必須包含2個(gè)大寫(xiě)字母
  • 必須包含1個(gè)特殊字符

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

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

方案2分析

字符類(lèi) .

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

正向先行斷言 (?= )

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

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

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

方案2測(cè)試

給出測(cè)試結(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é)

以上所述是小編給大家介紹的密碼強(qiáng)度的正則表達(dá)式兩種方案JS總結(jié)篇,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!

您可能感興趣的文章:
  • js判斷密碼強(qiáng)度的方法
  • JS正則表達(dá)式驗(yàn)證密碼強(qiáng)度
  • 原生js實(shí)現(xiàn)密碼強(qiáng)度驗(yàn)證功能
  • JavaScript實(shí)現(xiàn)密碼強(qiáng)度實(shí)時(shí)驗(yàn)證
  • js如何驗(yàn)證密碼強(qiáng)度
  • js驗(yàn)證密碼強(qiáng)度解析
  • js正則表達(dá)式驗(yàn)證密碼強(qiáng)度【推薦】
  • js檢測(cè)用戶(hù)輸入密碼強(qiáng)度
  • js密碼強(qiáng)度實(shí)時(shí)檢測(cè)代碼
  • javascrpt密碼強(qiáng)度校驗(yàn)函數(shù)詳解

標(biāo)簽:常州 ???/a> 涼山 本溪 大興安嶺 湖州 泰安 哈密

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《密碼強(qiáng)度的正則表達(dá)式兩種方案JS總結(jié)篇》,本文關(guān)鍵詞  密碼,強(qiáng)度,的,正則,表達(dá)式,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《密碼強(qiáng)度的正則表達(dá)式兩種方案JS總結(jié)篇》相關(guān)的同類(lèi)信息!
  • 本頁(yè)收集關(guān)于密碼強(qiáng)度的正則表達(dá)式兩種方案JS總結(jié)篇的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章