工具类 - 身份证号码校验、升级

身份证号码校验、升级

 

一、18位身份证

 

公民18位身份证号码组成:地址码(6位)+ 出生日期码(8位)+ 顺序码(3位) + 校验码(1位)

 

地址码

1-2 位省、自治区、直辖市代码
3-4 位地级市、盟、自治州代码
5-6 位县、县级市、区代码

 

顺序码

表示在同一地址码所标识的区域范围内,对同年、同月、同日出生的人编定的顺序号,顺序码的奇数分配给男性,偶数分配给女性。

 

校验码

作为尾号的校验码,是由号码编制单位按统一的公式计算出来的,计算公式如下:

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。(即馀数0对应1,馀数1对应0,馀数2对应X...)
5、通过上面得知如果余数是3,就会在身份证的第18位数字上出现的是9。如果对应的数字是2,身份证的最后一位号码就是罗马数字x。

 

二、15位身份证

 

公民第一代身份是15位的,其中六位数字地址码(同18位),但出生日期只有年代,没有带世纪19,三位数字顺序码,没有校验码。

 

在升级时,需要在六位数字地址码后加上世纪19(因为15位身份证都是2000年前的了,之后的身份证都是18位的了),还要生成校验码

 

18位身份证号码校验

 

Boolean verifyIdNumber(String idNumber)
{
    def city = [11: "北京",
        12: "天津",
        13: "河北",
        14: "山西",
        15: "内蒙古",
        21: "辽宁",
        22: "吉林",
        23: "黑龙江 ",
        31: "上海",
        32: "江苏",
        33: "浙江",
        34: "安徽",
        35: "福建",
        36: "江西",
        37: "山东",
        41: "河南",
        42: "湖北 ",
        43: "湖南",
        44: "广东",
        45: "广西",
        46: "海南",
        50: "重庆",
        51: "四川",
        52: "贵州",
        53: "云南",
        54: "西藏 ",
        61: "陕西",
        62: "甘肃",
        63: "青海",
        64: "宁夏",
        65: "新疆",
        71: "台湾",
        81: "香港",
        82: "澳门",
        91: "国外 "]
    if (!(idNumber?.matches(/^(\d{15}$|^\d{18}$|^\d{17}(\d|X|x))$/)))
    {
        return false
    }
    else if (!city[Integer.parseInt(idNumber?.substring(0, 2))])
    {
        return false
    }
    else
    {
        if (idNumber?.length() == 18)
        {
            def factor = [7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2]
            def parity = ['1', '0', 'X', '9', '8', '7', '6', '5', '4', '3', '2']
            def sum = 0
            def ai = 0
            def wi = 0
            for (int i = 0; i < 17; i++)
            {
                ai = Integer.parseInt(String.valueOf(idNumber?.charAt(i)))
                wi = factor[i]
                sum += ai * wi
            }
            def index = sum % 11
            if (index == 2 && idNumber[17] != 'x' && idNumber[17] != 'X')
            {
                return false
            }
            if (index != 2 && parity[index] != idNumber[17])
            {
                return false
            }
        } 
    }
    return true
}

 

15位身份证号码升级

 

def getNewIdNumber(String oldId)
{
    if(oldId && oldId.matches(/^\d{15}$/))
    {
        StringBuilder newId = new StringBuilder()
        newId.append(oldId.substring(0, 6)).append("19").append(oldId.substring(6))
        newId.append(getVerifyCode(newId.toString()))
        
        // 18位身份证号码校验
        if (verifyIdNumber(newId.toString()))
        {
         return newId.toString()
        }
    }
}

def getVerifyCode(String oldId)
{
    def factor = [7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2]
    def parity = ['1', '0', 'X', '9', '8', '7', '6', '5', '4', '3', '2']
    def sum = 0
    def ai = 0
    def wi = 0
    for (int i = 0; i < 17; i++)
    {
        ai = Integer.parseInt(String.valueOf(oldId?.charAt(i)))
        wi = factor[i]
        sum += ai * wi
    }
    def index = sum % 11
    return parity[index]
}

 

 

 

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值