一个匹配数字和字母密码的正则表达式
一个用户注册功能的密码有如下要求:由数字和字母组成,并且要同时含有数字和字母,且长度要在8-16位之间。
如何分析需求?拆分!这就是软件设计的一般思路了。于是乎,拆分需求如下:
1,不能全部是数字
2,不能全部是字母
3,必须是数字或字母
只要能同时满足上面3个要求就可以了,写出来如下:
^(?![0-9]+$)(?![a-zA-Z]+$)[0-9A-Za-z]{8,16}$
分开来注释一下:
^ 匹配一行的开头位置
(?![0-9]+$) 预测该位置后面不全是数字
(?![a-zA-Z]+$) 预测该位置后面不全是字母
[0-9A-Za-z] {8,16} 由8-16位数字或这字母组成
$ 匹配行结尾位置
注:(?!xxxx) 是正则表达式的负向零宽断言一种形式,标识预该位置后不是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"; // 纯数字
System.out.println(value.matches(regex));
value = "aaaaaaaaa"; // 纯字母
System.out.println(value.matches(regex));
value = "####@@@@#"; // 特殊字符
System.out.println(value.matches(regex));
value = "1111aaaa"; // 数字字母组合
System.out.println(value.matches(regex));
value = "aaaa1111"; // 数字字母组合
System.out.println(value.matches(regex));
value = "aa1111aa"; // 数字字母组合
System.out.println(value.matches(regex));
value = "11aaaa11"; // 数字字母组合
System.out.println(value.matches(regex));
value = "aa11aa11"; // 数字字母组合
System.out.println(value.matches(regex));
}
}
采用普通方式:(只能由字母数字下划线和$)
public static void main(String[] args) throws Exception {
Scanner scan=new Scanner(System.in);
String str=scan.nextLine();
char[] ch = str.toCharArray();
boolean ok=true;
for(int i=0;i<str.length();i++){
if(!Character.isLetter(ch[i])&&!Character.isDigit(ch[i])&&!Character.toString(ch[i]).equals("_")&&!Character.toString(ch[i]).equals("$")){
ok=false;
}
}
if(ok){
System.out.print("符合");
}else{
System.out.print("不符合");
}
}
采用普通方式:(必须有字母数字和(下划线或$))
public class test1 {
public static void main(String[] args) throws Exception {
Scanner scan=new Scanner(System.in);
String str=scan.nextLine();
char[] ch = str.toCharArray();
if(containNum(ch)&&containLetter(ch)&&(str.contains("_")||str.contains("$"))){
System.out.print("符合");
}else{
System.out.print("不符合");
}
}
public static boolean containNum(char ch[]){
boolean contain=false;
for(int i=0;i<ch.length;i++){
if(Character.isDigit(ch[i])){
contain=true;
}
}
return contain;
}
public static boolean containLetter(char ch[]){
boolean contain=false;
for(int i=0;i<ch.length;i++){
if(Character.isLetter(ch[i])){
contain=true;
}
}
return contain;
}
}
判断字符串中是否包含特殊字符的正则解法
import java.util.regex.*;
public class patternDemo {
public static void main(String[] args) {
String str = "yaopipeidezifuchuan#%#%@%";
String regEx = "[`[email protected]#$%^&*()_+=|{}':;',\\[\\].<>/?~!@#¥%……&*()——+|{}【】‘;:”“’。,、?]";
Pattern p = Pattern.compile(regEx);
Matcher m = p.matcher(str);
System.out.println(m.find());
}
}