日本免费高清视频-国产福利视频导航-黄色在线播放国产-天天操天天操天天操天天操|www.shdianci.com

學無先后,達者為師

網站首頁 編程語言 正文

常用正則表達式之密碼格式驗證大全_正則表達式

作者:TinyMaD ? 更新時間: 2022-04-20 編程語言

前言

這里有你想要的正則表達式。網上這方面的內容比較分散,本文將盡量寫出驗證各種密碼格式的正則表達式,漏了的情況請留言提示我進行添加,如果對你有幫助,麻煩給我一個贊,謝謝。

話不多說,直接上答案。

示例

1種

只能由1種組成

只能由字母組成,1-9位

^[a-zA-Z]{1,9}$

只能由數字組成,1-9位

^\d{1,9}$

只能由特殊字符組成,1-9位

^[^\da-zA-Z\s]{1,9}$

至少包含1種

至少包含字母,1-9位

^(?=.*[a-zA-Z]).{1,9}$

至少包含數字,1-9位

^(?=.*\d).{1,9}$

至少包含特殊字符,1-9位

^(?=.*[^\da-zA-Z\s]).{1,9}$

2種

只能由2種組成

只能由字母、數字組成,1-9位

^(?=.*\d)(?=.*[A-z])[\da-zA-Z]{1,9}$

只能由字母、特殊字符組成,1-9位

^(?=.*[a-zA-Z])(?=.*[^\da-zA-Z\s])([a-zA-Z]|[^\da-zA-Z\s]){1,9}$

只能由數字、特殊字符組成,1-9位

^(?=.*\d)(?=.*[^\da-zA-Z\s])(\d|[^\da-zA-Z\s]){1,9}$

至少包含2種

至少包含字母、數字,1-9位

^(?=.*[a-zA-Z])(?=.*\d).{1,9}$

至少包含字母、特殊字符,1-9位

^(?=.*[a-zA-Z])(?=.*[^\da-zA-Z\s]).{1,9}$

至少包含數字、特殊字符,1-9位

^(?=.*\d)(?=.*[^\da-zA-Z\s]).{1,9}$

任意2種組成

由字母、數字、特殊字符,任意2種組成,1-9位

^(?![a-zA-Z]+$)(?!\d+$)(?![^\da-zA-Z\s]+$).{1,9}$

3種

至少包含3種

至少包含字母、數字、特殊字符,1-9位

^(?=.*\d)(?=.*[a-zA-Z])(?=.*[^\da-zA-Z\s]).{1,9}$

至少包含字母、數字、特殊字符,1-9位,并且不能連續出現3個大小連續或相同的數字(如:456、654、888)

^(?=.*\d)(?!.*(\d)\1{2})(?!.*(012|123|234|345|456|567|678|789|987|876|765|654|543|432|321|210))(?=.*[a-zA-Z])(?=.*[^\da-zA-Z\s]).{1,9}$

詳解

吐槽

這塊內容一般放在前言里的,但對于正則表達式的內容,寫在上面有些多余,因為正則表達式這東西用的時候很少,一部分人可能對怎么寫不感興趣,或者要用的時候比較急,只想復制粘貼后能正常運行,我朋友就屬于前兩者(醫生:你說的這個朋友,是不是你自己呀.jpg)。

看到這兒的應該是沒那么急的,那么下面我們就來聊聊——寫出滿足密碼驗證條件的正則表達式,需要了解哪些關鍵語法?

正文

字符 描述
^ 匹配輸入字符串的開始位置。
$ 匹配輸入字符串的結束位置。
* 匹配前面的子表達式零次或多次。例如,zo*能匹配“z”以及“zoo”。*等價于{0,}。
+ 匹配前面的子表達式一次或多次。例如,“zo+”能匹配“zo”以及“zoo”,但不能匹配“z”。+等價于{1,}。
? 匹配前面的子表達式零次或一次。例如,“do(es)?”可以匹配“does”或“does”中的“do”。?等價于{0,1}。
{n,m} 最少匹配n次且最多匹配m次。例如,“o{1,3}”將匹配“fooooood”中的前三個o?!皁{0,1}”等價于“o?”。
. 匹配除換行符之外的任何單個字符。
[a-z] 匹配任意小寫字母。
[A-Z] 匹配任意大寫字母。
[a-zA-Z] 匹配任意字母,不區分大小寫。
\d 匹配一個數字。等價于[0-9]。
\s 匹配任何空白字符,包括空格、制表符、換頁符等等。等價于[ \f\n\r\t\v]。
(?=pattern) 正向肯定預查。例如,“Windows(?=2000)”能匹配“Windows2000”中的“Windows”,但不能匹配“Windows3.1”中的“Windows”。
(?!pattern) 正向否定預查。例如“Windows(?!2000)”能匹配“Windows3.1”中的“Windows”,但不能匹配“Windows2000”中的“Windows”。
x|y 匹配x或y。例如,“z|food”能匹配“z”或“food”?!?z|f)ood”則匹配“zood”或“food”。
[xyz] 字符集合。匹配所包含的任意一個字符。例如,“[abc]”可以匹配“plain”中的“a”。
[^xyz] 負值字符集合。匹配未包含的任意字符。例如,“[^abc]”可以匹配“plain”中的“p”。

上面這些語法應該是大家最常見的、也是最基礎的,但對寫密碼格式驗證的正則表達式來說,不是最關鍵的。

關鍵是下面3套組合拳:

  • (?=.*x)

    必須有x。

    例:必須有數字——?(?=.*\d)?,以此類推。

  • (?!.*x)

    不能有x。

    例:不能有數字——?(?!.*\d)?,以此類推。

  • (?!x+$)

    不能全是某一種字符。

    例:不能全是數字——?(?!\d+$)?,以此類推。

有了上面的公式,再去看前面的示例應該就比較好理解了。

這里有些人可能就有點疑惑了——上面的表中不是寫的?(?=pattern)?表示在特定字符前,匹配前面的字符嗎?如:

Windows(?=2000)?能匹配“Windows2000”中的“Windows”,怎么跟后面提到的用法不一樣。

這是因為?Windows(?=2000)?中的“Windows”不僅僅只表示要獲取的字符,同時還是一個篩選條件——當“2000”前面是“Windows”時,即:?Windows(?=Windows2000)?,根據這個思路將正則表達式改為?(?=Windows2000)Windows?同樣也是能匹配“Windows2000”中的“Windows”的。所以,當我們不在意“2000”前面有沒有“Windows”,甚至不在意前面有沒有字符時,?(?=.*2000)?就代表必須有“2000”,才匹配字符串了。

附簡單的正則表達式例子

/** 
* @ClassName: RexTest 
* @Description: TODO
* @author BMR
* @date 2016年3月28日 上午11:09:17 
*/
public class RexTest {
    /**
     * 正則表達式驗證昵稱
     * @param nickName
     * @return
     */
    public static boolean rexCheckNickName(String nickName) {
        // 昵稱格式:限16個字符,支持中英文、數字、減號或下劃線
        String regStr = "^[\\u4e00-\\u9fa5_a-zA-Z0-9-]{1,16}$";
        return nickName.matches(regStr);
    }

    /**
     * 正則表達式驗證密碼
     * @param input
     * @return
     */
    public static boolean rexCheckPassword(String input) {
        // 6-20 位,字母、數字、字符
        //String reg = "^([A-Z]|[a-z]|[0-9]|[`-=[];,./~!@#$%^*()_+}{:?]){6,20}$";
        String regStr = "^([A-Z]|[a-z]|[0-9]|[`~!@#$%^&*()+=|{}':;',\\\\[\\\\].<>/?~!@#¥%……&*()——+|{}【】‘;:”“'。,、?]){6,20}$";
        return input.matches(regStr);
    }
    
    public static void main(String[] args){
        System.out.println("rexCheckPassword is: "+ rexCheckPassword("14`~!@#$%^&*(\\)+=|{}"));
        System.out.println("rexCheckNickName is: "+ rexCheckNickName("中英文-數字_減號或下劃線"));
        System.out.println("rexCheckNickName is: "+ rexCheckNickName("12文、數字、@"));
    }

輸出結果:

rexCheckPassword is: true
rexCheckNickName is: true
rexCheckNickName is: false

最后

之所以寫這個隨筆,也是由于最近在找一個密碼驗證的正則表達式,找了好久都沒有一個滿意的。搜到的文章里有示例的不夠全面,或者詳解部分不夠針對,不符合應用場景。在看了一些資料后,終于寫出了需要的正則表達式,后來意識到可能大家也會遇到跟我類似的情況,所以就想挑戰一下自己,算是完善自身,幫助他人,我想這也是大家寫博客的初衷。

原文鏈接:https://www.cnblogs.com/tinymad/p/15836480.html

欄目分類
最近更新