這篇文章主要介紹如何實現(xiàn)匹配數(shù)字和字母密碼的正則表達(dá)式,文中介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們一定要看完!
站在用戶的角度思考問題,與客戶深入溝通,找到寶坻網(wǎng)站設(shè)計與寶坻網(wǎng)站推廣的解決方案,憑借多年的經(jīng)驗,讓設(shè)計與互聯(lián)網(wǎng)技術(shù)結(jié)合,創(chuàng)造個性化、用戶體驗好的作品,建站類型包括:做網(wǎng)站、成都網(wǎng)站制作、企業(yè)官網(wǎng)、英文網(wǎng)站、手機(jī)端網(wǎng)站、網(wǎng)站推廣、國際域名空間、網(wǎng)絡(luò)空間、企業(yè)郵箱。業(yè)務(wù)覆蓋寶坻地區(qū)。
一個用戶注冊功能的密碼有如下要求:由數(shù)字和字母組成,并且要同時含有數(shù)字和字母,且長度要在8-16位之間。
如何分析需求?拆分!這就是軟件設(shè)計的一般思路了。于是乎,拆分需求如下:
1,不能全部是數(shù)字
2,不能全部是字母
3,必須是數(shù)字或字母
只要能同時滿足上面3個要求就可以了,寫出來如下:
^(?![0-9]+$)(?![a-zA-Z]+$)[0-9A-Za-z]{8,16}$
分開來注釋一下:
^ 匹配一行的開頭位置
(?![0-9]+$) 預(yù)測該位置后面不全是數(shù)字
(?![a-zA-Z]+$) 預(yù)測該位置后面不全是字母
[0-9A-Za-z] {8,16} 由8-16位數(shù)字或這字母組成
$ 匹配行結(jié)尾位置
注:(?!xxxx) 是正則表達(dá)式的負(fù)向零寬斷言一種形式,標(biāo)識預(yù)該位置后不是xxxx字符。
測試用例如下:
public class Test { public static void main(String[] args) throws Exception { String regex = "^(?![0-9]+$)(?![a-zA-Z]+$)[0-9A-Za-z]{8,16}$"; String value = "aaa"; // 長度不夠 System.out.println(value.matches(regex)); value = "1111aaaa1111aaaaa"; // 太長 System.out.println(value.matches(regex)); value = "111111111"; // 純數(shù)字 System.out.println(value.matches(regex)); value = "aaaaaaaaa"; // 純字母 System.out.println(value.matches(regex)); value = "####@@@@#"; // 特殊字符 System.out.println(value.matches(regex)); value = "1111aaaa"; // 數(shù)字字母組合 System.out.println(value.matches(regex)); value = "aaaa1111"; // 數(shù)字字母組合 System.out.println(value.matches(regex)); value = "aa1111aa"; // 數(shù)字字母組合 System.out.println(value.matches(regex)); value = "11aaaa11"; // 數(shù)字字母組合 System.out.println(value.matches(regex)); value = "aa11aa11"; // 數(shù)字字母組合 System.out.println(value.matches(regex)); } }
以上是“如何實現(xiàn)匹配數(shù)字和字母密碼的正則表達(dá)式”這篇文章的所有內(nèi)容,感謝各位的閱讀!希望分享的內(nèi)容對大家有幫助,更多相關(guān)知識,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!