首页 > 代码库 > java判断身份证有效性

java判断身份证有效性

import java.util.Calendar;public class CertNoUtil {    public static boolean vIDNumByRegex(String idNum) {        String curYear = "" + Calendar.getInstance().get(Calendar.YEAR);        int y3 = Integer.valueOf(curYear.substring(2, 3));        int y4 = Integer.valueOf(curYear.substring(3, 4));        // 43 0103 1973 0 9 30 051 9        return idNum.matches("^(1[1-5]|2[1-3]|3[1-7]|4[1-6]|5[0-4]|6[1-5]|71|8[1-2])\\d{4}(19\\d{2}|20([0-" + (y3 - 1) + "][0-9]|" + y3 + "[0-" + y4                + "]))(((0[1-9]|1[0-2])(0[1-9]|[1-2][0-9]|3[0-1])))\\d{3}([0-9]|x|X)$");        // 44 1825 1988 0 7 1 3 003 4    }    private static int ID_LENGTH = 17;    public static boolean vIDNumByCode(String idNum) {        // 系数列表        int[] ratioArr = {7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2};        // 校验码列表        char[] checkCodeList = {‘1‘, ‘0‘, ‘X‘, ‘9‘, ‘8‘, ‘7‘, ‘6‘, ‘5‘, ‘4‘, ‘3‘, ‘2‘};        // 获取身份证号字符数组        char[] cIds = idNum.toCharArray();        // 获取最后一位(身份证校验码)        char oCode = cIds[ID_LENGTH];        int[] iIds = new int[ID_LENGTH];        int idSum = 0;// 身份证号第1-17位与系数之积的和        int residue = 0;// 余数(用加出来和除以11,看余数是多少?)        for (int i = 0; i < ID_LENGTH; i++) {            iIds[i] = cIds[i] - ‘0‘;            idSum += iIds[i] * ratioArr[i];        }        residue = idSum % 11;// 取得余数        return Character.toUpperCase(oCode) == checkCodeList[residue];    }    public static boolean vId(String idNum) {        return vIDNumByCode(idNum) && vIDNumByRegex(idNum);    }    public static void main(String[] args) {        String idNum = "430103197309300519";        System.out.println(vId(idNum));    }}

 

java判断身份证有效性