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次,就会成功了