身份证验证

阅读更多

 

public static boolean validateIdcard(String id) {
		String Ai = null;
		// 取出身份证前n-1位
		if( id.length() == 18 ) {
			Ai = id.substring(0, 17);
		} else if( id.length() == 15 ) {
			Ai = id.substring(0,6) + "19" + id.substring(6);
		} else {
			return false;
		}
		
		// 计算身份证前n-1位的权重和,算出最后一位
		int[] Wi = { 7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2 };
		int sum = 0;
		for (int i = 0; i <= 16; i++) {
			int num = Integer.parseInt(Ai.substring(i, i + 1));
			sum += num * Wi[i];
		}
		
		String verify = "10x98765432";
		
		// 身份证前n-1位 + 计算出的最后一位
		Ai += verify.charAt(sum % 11);
		
		return id.equalsIgnoreCase(Ai);
	}

 

如果知道是这种算法来验证的话,还是很容易破解的,把身份证前面乱写后,就把最后一位从10x98765432试一遍,最多尝试11次,就会成功了

 

你可能感兴趣的:(java)