首頁 > 軟體

Regex正規表示式判斷密碼強度

2023-02-03 18:02:16

需求

  最近在最做一個軟體的註冊登入的功能,需要用到對密碼強度的判斷,並對當前輸入的密碼的強度進行輸出。需求裡對密碼分了三級,分別是低強度、中強度、高強度,但是沒有對什麼是低強度、什麼是高強度進行詳細分類,所以自己在做的時候簡單做了下分類。對密碼分類後,我想到的是使用Regex表示式直接判斷密碼的強度,密碼字串輸入然後輸出對應強度等級就行。

  這裡用到Regex表示式,雖然還是經常使用,但是對其語法還是一知半解。主要一般用到都比較簡單,不需要多重判斷。在網上一番搜尋後,基本沒有找到符合我要求的Regex表示式。雖然可以用if...else...進行進行分步判斷,但是對於我等強迫症而言,能用一句程式碼說明的事情絕對不寫第二句。所以還是頭疼了好一會的。大體看了下別人怎麼寫的,簡單對照了下語法設計,然後開始著手自己的密碼強度判斷Regex表示式的書寫。

線上測試Regex

https://www.goregex.cn/

正文

密碼強度分類

  首先完成對密碼強度等級的分類。密碼為6-16位元,分為低、中、高3個等級。密碼是大小寫字母,數位,英文標點的隨機組合。密碼強度等級對照表:

長度描述強度
6<=長度<=8純數位
-純數位
-純字母
-純英文標點
-數位+字母
-數位+標點
-字母+標點
-數位+字母+標點
9<=長度<=12純數位
-純字母
-純英文標點
-數位+字母
-數位+標點
-字母+標點
-數位+字母+標點
13<=長度<=16所有

Regex分析

  Regex表示式再複雜也逃不過最基礎的與或非關係,我們完全可以從這方面對複雜的Regex表示式進行拆分。

  在此之前需要理解以下幾種符號的含義。

符號描述
^匹配輸入字串的開始位置
$匹配輸入字串的結束位置
.匹配除 "n" 之外的任何單個字元
*匹配前面的子表示式零次或多次
+匹配前面的子表示式一次或多次
?匹配前面的子表示式零次或一次
d匹配一個數位字元。等價於[0-9]
S匹配任何非空白字元
[xyz]字元種類。匹配⽅括號內的任意字元
(xyz)字元集,匹配與 xyz 完全相等的字串
[a-z]匹配 'a' 到 'z' 範圍內的任意小寫字母字元
(?=x)正向肯定預查詢包含x
{4,8}匹配4到8位元長度的字元
或運運算元
跳脫字元,⽤於匹配⼀些保留的字元{}.*+?^$|
[^x]匹配除了x以外的任意字元

  拿低強度的密碼來說,首先需要滿足6-8位元,其次全是數位或全是字母或全是標點符號,只滿足這兩個條件的就是低強度的密碼。拆分開後就好實現了。

先看怎麼實現滿足6-8位元的表示式。

^S{6,8}$ //任何非空白字元,且滿足6-8位元

匹配都是數位的情況。

^d+$

匹配都是字母的情況。

^[A-Za-z]+$

匹配都是符號的情況。

^[!@#$%^&*?=]+$

拼接在一起,就是低強度密碼的正規表示式:

(?=^d+$|^[A-Za-z]+$|^[!@#$%^&*?=]+$)^S{6,8}$

中強度密碼同理。

匹配6-8位元同時包含數位+字母的情況。可以理解為包含數位、字母的字串,但不全是數位或不全是字母。

(?=.*d)(?=.*[A-Za-z])(?=^[dA-Za-z]+$)^S{6,8}$

匹配6-8位元同時包含數位+標點(!@#$=%^&*?)的情況。同上。

(?=.*d)(?=.*[!@#$=%^&*?])(?=^[d!@#$=%^&*?]+$)^S{6,8}$

匹配6-8位元同時包含字母+標點的情況。同上。

(?=.*[A-Za-z])(?=.*[!@#$%^&*?])(?=^[A-Za-z!@#$=%^&*?]+$)^S{6,8}$

然後再加上匹配9-12位元純數位,純字母,純標點的情況。與之前的寫法相同。

高強度密碼同理。

補充:密碼強度 弱 中 強 正規表示式判斷

今天看了下專案中的註冊頁原始碼,順帶著看了下判斷密碼強度的正規表示式,寫的很好,最起碼比我寫的好,所以記錄下來留著以後參考
程式碼如下

var strongRegex = new RegExp("^(?=.{8,})(?=.*[A-Z])(?=.*[a-z])(?=.*[0-9])(?=.*\W).*$", "g")  //強
var mediumRegex = new RegExp("^(?=.{7,})(((?=.*[A-Z])(?=.*[a-z]))|((?=.*[A-Z])(?=.*[0-9]))|((?=.*[a-z])(?=.*[0-9]))).*$", "g")  //中
var enoughRegex = new RegExp("(?=.{6,}).*", "g") //弱

用input 的keyup() 方法每輸入一個字元用 正則的 enoughRegex.test(password) 方法去檢測密碼

本人之前也學過正規表示式的一點皮毛,下面從強到弱解釋下這三句正則的規則,如果有說的不對的地方歡迎大神拍磚,共同學習進步!

強 ==> 密碼長度大於等於8位元數 包含大寫字母[A-Z] + 小寫字母[a-z] + 數位[0-9] + 非單詞字元的特殊字元[標點符號,空格啥的這些] 結尾

中 ==> 密碼長度大於等於7位數 大寫字母[A-Z] + 小寫字母[a-z] 或者 大寫字母[A-Z] + 數位[0-9] 或者 小寫字母[a-z] + 數位[0-9] + 任意字元 結尾

弱 ==> 大於等於6位 任何字元或者數位 (如果達不到這個條件就是弱,所以這裡需要用false判斷)

到此這篇關於Regex正規表示式判斷密碼強度的文章就介紹到這了,更多相關正規表示式判斷密碼強度內容請搜尋it145.com以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援it145.com!


IT145.com E-mail:sddin#qq.com