常用正則表達(dá)式之密碼格式驗(yàn)證大全
前言
這里有你想要的正則表達(dá)式。網(wǎng)上這方面的內(nèi)容比較分散,本文將盡量寫出驗(yàn)證各種密碼格式的正則表達(dá)式,漏了的情況請(qǐng)留言提示我進(jìn)行添加,如果對(duì)你有幫助,麻煩給我一個(gè)贊,謝謝。
話不多說(shuō),直接上答案。
示例
1種
只能由1種組成
只能由字母組成,1-9位
^[a-zA-Z]{1,9}$
只能由數(shù)字組成,1-9位
^\d{1,9}$
只能由特殊字符組成,1-9位
^[^\da-zA-Z\s]{1,9}$
至少包含1種
至少包含字母,1-9位
^(?=.*[a-zA-Z]).{1,9}$
至少包含數(shù)字,1-9位
^(?=.*\d).{1,9}$
至少包含特殊字符,1-9位
^(?=.*[^\da-zA-Z\s]).{1,9}$
2種
只能由2種組成
只能由字母、數(shù)字組成,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}$
只能由數(shù)字、特殊字符組成,1-9位
^(?=.*\d)(?=.*[^\da-zA-Z\s])(\d|[^\da-zA-Z\s]){1,9}$
至少包含2種
至少包含字母、數(shù)字,1-9位
^(?=.*[a-zA-Z])(?=.*\d).{1,9}$
至少包含字母、特殊字符,1-9位
^(?=.*[a-zA-Z])(?=.*[^\da-zA-Z\s]).{1,9}$
至少包含數(shù)字、特殊字符,1-9位
^(?=.*\d)(?=.*[^\da-zA-Z\s]).{1,9}$
任意2種組成
由字母、數(shù)字、特殊字符,任意2種組成,1-9位
^(?![a-zA-Z]+$)(?!\d+$)(?![^\da-zA-Z\s]+$).{1,9}$
3種
至少包含3種
至少包含字母、數(shù)字、特殊字符,1-9位
^(?=.*\d)(?=.*[a-zA-Z])(?=.*[^\da-zA-Z\s]).{1,9}$
至少包含字母、數(shù)字、特殊字符,1-9位,并且不能連續(xù)出現(xiàn)3個(gè)大小連續(xù)或相同的數(shù)字(如: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}$
詳解
吐槽
這塊內(nèi)容一般放在前言里的,但對(duì)于正則表達(dá)式的內(nèi)容,寫在上面有些多余,因?yàn)檎齽t表達(dá)式這東西用的時(shí)候很少,一部分人可能對(duì)怎么寫不感興趣,或者要用的時(shí)候比較急,只想復(fù)制粘貼后能正常運(yùn)行,我朋友就屬于前兩者(醫(yī)生:你說(shuō)的這個(gè)朋友,是不是你自己呀.jpg)。
看到這兒的應(yīng)該是沒(méi)那么急的,那么下面我們就來(lái)聊聊——寫出滿足密碼驗(yàn)證條件的正則表達(dá)式,需要了解哪些關(guān)鍵語(yǔ)法?
正文
字符 | 描述 |
---|---|
^ | 匹配輸入字符串的開(kāi)始位置。 |
$ | 匹配輸入字符串的結(jié)束位置。 |
* | 匹配前面的子表達(dá)式零次或多次。例如,zo*能匹配“z”以及“zoo”。*等價(jià)于{0,}。 |
+ | 匹配前面的子表達(dá)式一次或多次。例如,“zo+”能匹配“zo”以及“zoo”,但不能匹配“z”。+等價(jià)于{1,}。 |
? | 匹配前面的子表達(dá)式零次或一次。例如,“do(es)?”可以匹配“does”或“does”中的“do”。?等價(jià)于{0,1}。 |
{n,m} | 最少匹配n次且最多匹配m次。例如,“o{1,3}”將匹配“fooooood”中的前三個(gè)o。“o{0,1}”等價(jià)于“o?”。 |
. | 匹配除換行符之外的任何單個(gè)字符。 |
[a-z] | 匹配任意小寫字母。 |
[A-Z] | 匹配任意大寫字母。 |
[a-zA-Z] | 匹配任意字母,不區(qū)分大小寫。 |
\d | 匹配一個(gè)數(shù)字。等價(jià)于[0-9]。 |
\s | 匹配任何空白字符,包括空格、制表符、換頁(yè)符等等。等價(jià)于[ \f\n\r\t\v]。 |
(?=pattern) | 正向肯定預(yù)查。例如,“Windows(?=2000)”能匹配“Windows2000”中的“Windows”,但不能匹配“Windows3.1”中的“Windows”。 |
(?!pattern) | 正向否定預(yù)查。例如“Windows(?!2000)”能匹配“Windows3.1”中的“Windows”,但不能匹配“Windows2000”中的“Windows”。 |
x|y | 匹配x或y。例如,“z|food”能匹配“z”或“food”。“(z|f)ood”則匹配“zood”或“food”。 |
[xyz] | 字符集合。匹配所包含的任意一個(gè)字符。例如,“[abc]”可以匹配“plain”中的“a”。 |
[^xyz] | 負(fù)值字符集合。匹配未包含的任意字符。例如,“[^abc]”可以匹配“plain”中的“p”。 |
上面這些語(yǔ)法應(yīng)該是大家最常見(jiàn)的、也是最基礎(chǔ)的,但對(duì)寫密碼格式驗(yàn)證的正則表達(dá)式來(lái)說(shuō),不是最關(guān)鍵的。
關(guān)鍵是下面3套組合拳:
- (?=.*x)
必須有x。
例:必須有數(shù)字—— (?=.*\d) ,以此類推。
- (?!.*x)
不能有x。
例:不能有數(shù)字—— (?!.*\d) ,以此類推。
- (?!x+$)
不能全是某一種字符。
例:不能全是數(shù)字—— (?!\d+$) ,以此類推。
有了上面的公式,再去看前面的示例應(yīng)該就比較好理解了。
這里有些人可能就有點(diǎn)疑惑了——上面的表中不是寫的 (?=pattern)
表示在特定字符前,匹配前面的字符嗎?如:
Windows(?=2000)
能匹配“Windows2000”中的“Windows”,怎么跟后面提到的用法不一樣。
這是因?yàn)?nbsp;Windows(?=2000)
中的“Windows”不僅僅只表示要獲取的字符,同時(shí)還是一個(gè)篩選條件——當(dāng)“2000”前面是“Windows”時(shí),即: Windows(?=Windows2000)
,根據(jù)這個(gè)思路將正則表達(dá)式改為 (?=Windows2000)Windows
同樣也是能匹配“Windows2000”中的“Windows”的。所以,當(dāng)我們不在意“2000”前面有沒(méi)有“Windows”,甚至不在意前面有沒(méi)有字符時(shí), (?=.*2000)
就代表必須有“2000”,才匹配字符串了。
附簡(jiǎn)單的正則表達(dá)式例子
/** * @ClassName: RexTest * @Description: TODO * @author BMR * @date 2016年3月28日 上午11:09:17 */ public class RexTest { /** * 正則表達(dá)式驗(yàn)證昵稱 * @param nickName * @return */ public static boolean rexCheckNickName(String nickName) { // 昵稱格式:限16個(gè)字符,支持中英文、數(shù)字、減號(hào)或下劃線 String regStr = "^[\\u4e00-\\u9fa5_a-zA-Z0-9-]{1,16}$"; return nickName.matches(regStr); } /** * 正則表達(dá)式驗(yàn)證密碼 * @param input * @return */ public static boolean rexCheckPassword(String input) { // 6-20 位,字母、數(shù)字、字符 //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("中英文-數(shù)字_減號(hào)或下劃線")); System.out.println("rexCheckNickName is: "+ rexCheckNickName("12文、數(shù)字、@")); }
輸出結(jié)果:
rexCheckPassword is: true
rexCheckNickName is: true
rexCheckNickName is: false
最后
之所以寫這個(gè)隨筆,也是由于最近在找一個(gè)密碼驗(yàn)證的正則表達(dá)式,找了好久都沒(méi)有一個(gè)滿意的。搜到的文章里有示例的不夠全面,或者詳解部分不夠針對(duì),不符合應(yīng)用場(chǎng)景。在看了一些資料后,終于寫出了需要的正則表達(dá)式,后來(lái)意識(shí)到可能大家也會(huì)遇到跟我類似的情況,所以就想挑戰(zhàn)一下自己,算是完善自身,幫助他人,我想這也是大家寫博客的初衷。
到此這篇關(guān)于常用正則表達(dá)式之密碼格式驗(yàn)證大全的文章就介紹到這了,更多相關(guān)正則表達(dá)式密碼格式驗(yàn)證內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
正則表達(dá)式之字符組[?](Character?Classes)
字符組是正則表達(dá)式最基本的結(jié)構(gòu)之一,這里就為大家介紹一下字符組[]的正確使用方法,需要的朋友可以參考下2023-05-05