摘要:簡言本文給出了兩個密碼強度的正則表達式方案,一個簡單,一個更復雜和安全。要寫出正確的正則表達式,先要定義表達式規則。重復在正則表達式中用來表示元素重復出現的次數。你可以根據項目需要,自己調整上述正則表達式。
簡言
本文給出了兩個密碼強度的正則表達式方案,一個簡單,一個更復雜和安全。并分別給出了兩個方案的解析和測試程序。一般大家可以根據自己的項目的實際需要,自行定義自己的密碼正則約定。
前言用戶注冊時,都會用到密碼正則校驗。要寫出正確的正則表達式,先要定義表達式規則。
方案1 (簡單)假設密碼驗證做如下規則定義:
最短6位,最長16位 {6,16}
可以包含小寫大母 [a-z] 和大寫字母 [A-Z]
可以包含數字 [0-9]
可以包含下劃線 [ _ ] 和減號 [ - ]
根據以上規則,很容易給出正則字面量定義如下:
var pattern = /^[w_-]{6,16}$/;方案1分析 字面量 / /
正則表達式的字面量定義為包含在一對斜杠(/)之間的字符,例如:
var pattern = /s$/;
上述字面量匹配所有以字母“s”結尾的字符串。
字符類 [ ]將字符放進方括號內就組成了字符類。一個字符類可以匹配它所包含的任意字符。因此,正則表達式/[abc]/就和字母“a”,“b”,“c”中的任意一個都匹配。
字符類可以使用連字符來表示字符范圍。要匹配拉丁小寫字母可以使用/[a-z]/。
字符類 w字符類 w 匹配任何ASCII字符組成的單詞,等價于[a-zA-Z0-9]。
[w_-]表示匹配任意的拉丁大小寫字母,數字再加上下劃線和減號。
重復 {}在正則表達式中用{ }來表示元素重復出現的次數。
{n,m} 匹配前一項至少n次,但不能超過m次
{n,} 匹配前一項n次或更多次
{n} 匹配前一項n次
[w_-]{6,16} 表示匹配任意的拉丁大小寫字母,數字再加上下劃線和減號出現最少6次,最多16次。
匹配位置^ 匹配字符串的開頭,在多行檢索中,匹配一行的開頭
$ 匹配字符串的結尾,在多行檢索中,匹配一行的結尾
/^w/ 匹配以大小寫字母或數字開頭的字符串。
方案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;
查看源碼
根據測試結果可以看出,方案1只是對密碼做了簡單的限定,不能保證密碼的強度和帳號安全。
方案2 (安全)假設密碼驗證做如下規則定義:
最短6位,最長16位 {6,16}
必須包含1個數字
必須包含2個小寫字母
必須包含2個大寫字母
必須包含1個特殊字符
根據以上規則,很容易給出正則字面量定義如下:
var pattern = /^.*(?=.{6,16})(?=.*d)(?=.*[A-Z]{2,})(?=.*[a-z]{2,})(?=.*[!@#$%^&*?()]).*$/;方案2分析 字符類 .
字符類 . 表示除換行符和其他Unicode行終止符之外的任意字符。
正向先行斷言 (?= )在符號“(?=” 和 “)” 之間加入一個表達式,它就是一個先行斷言,用以說明圓括號內的表達式必須正確匹配。比如:/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;
查看源碼
從以上測試可以看出,密碼足夠強壯和安全。你可以根據項目需要,自己調整上述正則表達式。
原文鏈接
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://specialneedsforspecialkids.com/yun/93286.html
摘要:用戶名正則用戶名正則,到位字母,數字,下劃線,減號輸出密碼強度正則密碼強度正則,最少位,包括至少個大寫字母,個小寫字母,個數字,個特殊字符輸出整數正則正整數正則負整數正則整數正則輸出輸出輸出數字正則可以是整數也可以是浮點 1 用戶名正則 //用戶名正則,4到16位(字母,數字,下劃線,減號) var uPattern = /^[a-zA-Z0-9_-]{4,16}$/; //輸出 tr...
摘要:方案簡單方案算法通過密碼構成分析,結合權重分派,統計得出密碼強度得分。 簡言 用正則表達式做用戶密碼強度的通過性判定,過于簡單粗暴,不但用戶體驗差,而且用戶帳號安全性也差。那么如何準確評價用戶密碼的強度,保護用戶帳號安全呢?本文分析介紹了幾種基于規則評分的密碼強度檢測算法,并給出了相應的演示程序。大家可以根據自己項目安全性需要,做最適合于自己的方案選擇。 showImg(http://...
閱讀 2133·2023-04-26 03:06
閱讀 3580·2023-04-26 01:51
閱讀 2086·2021-11-24 09:38
閱讀 2452·2021-11-17 17:00
閱讀 2324·2021-09-28 09:36
閱讀 942·2021-09-24 09:47
閱讀 2587·2019-08-30 15:54
閱讀 1555·2019-08-30 15:44