Java校验身份证算法

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,算法,开发语言)