private final static Pattern idcard = Pattern.compile("\\^(^[1-9]\\d{7}((0\\d)|(1[0-2]))(([0|1|2]\\d)|3[0-1])\\d{3}$)|(^[1-9]\\d{5}[1-9]\\d{3}((0\\d)|(1[0-2]))(([0|1|2]\\d)|3[0-1])((\\d{4})|\\d{3}[Xx])$)$");
public boolean check(String idCard) {
if (idcard.matcher(idCard).matches()) {
if (idCard.length() == 18) {
//将前17位加权因子保存在数组里
int[] idCardWi = {7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2};
//这是除以11后,可能产生的11位余数、验证码,也保存成数组
int[] idCardY = {1, 0, 10, 9, 8, 7, 6, 5, 4, 3, 2};
//用来保存前17位各自乖以加权因子后的总和
int idCardWiSum = 0;
for (int i = 0; i < 17; i++) {
idCardWiSum += Integer.valueOf(idCard.substring(i, i + 1)) * idCardWi[i];
}
int idCardMod = idCardWiSum % 11;//计算出校验码所在数组的位置
String idCardLast = idCard.substring(17);//得到最后一位身份证号码
//如果等于2,则说明校验码是10,身份证号码最后一位应该是X
if (idCardMod == 2) {
if (idCardLast.equalsIgnoreCase("X")) {
return true;
} else {
Log.i(TAG, "尾数验证错误 ");
}
} else {
//用计算出的验证码与最后一位身份证号码匹配,如果一致,说明通过,否则是无效的身份证号码
if (idCardLast.equals(String.valueOf(idCardY[idCardMod]))) {
return true;
} else {
Log.i(TAG, "check: 身份证无效");
}
}
} else {
Log.i(TAG, "长度不够 ");
}
} else {
Log.i("TAG", "身份证格式错误");
}
return false;
}
记录个身份证号验证代码。逻辑参考的网上的。自己验证了几个号码。没啥问题。
你可以拿去用,不过我也不保证百分百哈。运用了正则和严格的检查。只能检查18位身份证号。
正则也不知道对不对。如果错了还告诉我正确写法。