身份证验证
?
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次,就会成功了
?