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

被折叠的 条评论
为什么被折叠?



