天天看点

java正则校验,密码必须由字母和数字组成 一个匹配数字和字母密码的正则表达式

一个匹配数字和字母密码的正则表达式

一个用户注册功能的密码有如下要求:由数字和字母组成,并且要同时含有数字和字母,且长度要在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());  } }

继续阅读