public class ValidateIdCardUtil {
/*
1. 将身份证号码前面的17位数分别乘以不同的系数、从第一到第+位的系数分为7-9-10-5-8-4-2-1-6-3-7-9-10-5-8-4-2
2. 将这17位数字和系数相乘的结果相加。
3. 用加出来和除以11,取余数。
4. 余数只可能有0-1-2-3-4-5-6-7-8-9-10这11个数字,
其分别对应的最后一位身份证的号码为1-0-X-9-8-7-6-5-4-3-2.
5. 通过上面计算得知如果余数是3,第18位的按验码就是9,如果余数是2那么对应的校验码就是X,X实际是罗马数字1.
*/
private static String[] validtable = {"1", "0", "X", "9", "8", "7", "6", "5", "4", "3", "2"};
public static boolean checkIdNumber(String ID) {
boolean flag = false;
if (18 != ID.length()) {
return flag;
}
//验证码
String validateCode = ID.substring(17, 18);
//前17位称为本体码
String selfCode = ID.substring(0, 17);
String code[] = new String[17];
for (int i = 0; i < 17; i++) {
code[i] = selfCode.substring(i, i + 1);
}
//加权因子公式:2*n-1除以11取余数,n就是那个i,从右向左排列。
//用于加权数求和
int sum = 0;
for (int i = 0; i < code.length; i++) {
//计算该位加权因子
int yi = adjustmentFactor(i + 1) % 11;
//得到对应数位上的数字
int count = Integer.parseInt(code[code.length - i - 1]);
//加权求和
sum += (count * yi);
}
//验证校验码是否正确
String valDate = validtable[sum % 11];
if (valDate.equalsIgnoreCase(validateCode)) {
flag = true;
}
return flag;
}
/**
* 计算身份证数位数字加权因子
* digit表示数位
*/
public static int adjustmentFactor(int digit) {
int sum = 1;
for (int i = 0; i < digit; i++) {
//sum=sum*2;
sum = sum << 1;
}
return sum;
}
public static void main(String[] args) {
System.out.println(cleckIdNumber("身份证号码"));
}
}
Java校验身份证算法
于 2023-06-06 17:29:38 首次发布