js验证身份证号码记录

4次阅读

共计 2088 个字符,预计需要花费 6 分钟才能阅读完成。

在一些需要填写身份证的表单网页中,需要对身份证的输入做一个验证,于是,我记录下了自己写的验证。在写验证之前,我们需要理解身份证的一些常识规则。中华人民共和国居民身份证验证规则如下:

1. 号码的结构:

  • 公民身份号码是特征组合码,由十七位数字本体码和一位校验码组成。
  • 排列顺序从左至右依次为:六位数字地址码,八位数字出生日期码,
  • 三位数字顺序码和一位数字校验码。

2. 地址码

* 表示编码对象常住户口所在县(市、旗、区)的行政区划代码,按 GB/T2260 的规定执行。

3. 出生日期码

* 表示编码对象出生的年、月、日,按 GB/T7408 的规定执行,年、月、日代码之间不用分隔符。

4. 顺序码

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

5. 校验码

* 根据前面十七位数字码,按照 ISO 7064:1983.MOD 11- 2 校验码计算出来的检验码。

而计算方法则为:

  • 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。

例如:某男性的身份证号码为53010219200508011x,我们看看这个身份证是不是合法的身份证。

  • 首先我们得出前 17 位的乘积和 [(57)+(39)+(010)+(15)+(08)+(24)+(12)+(91)+(26)+(03)+(07)+(59)+(010)+(85)+(08)+(14)+(1*2)] 是 189,
  • 然后用 189 除以 11 得出的结果是 189/11=17—-2,也就是说其余数是 2。
  • 最后通过对应规则就可以知道余数 2 对应的检验码是 X。所以,可以判定这是一个正确的身份证号码。

根据以上的规则和计算方法,我们就可以封装一个验证身份证的函数,如下:

    const validateIdCard = function (idcard) {
        // 判断如果传入的不是一个字符串,则转换成字符串
        idcard = typeof idcard === 'string' ? idcard : String(idcard);
        // 正则表达式验证号码的结构
        let regx = /^[\d]{17}[0-9|X|x]{1}$/;
        if (regx.test(idcard)) {
            // 验证前面 17 位数字,首先定义前面 17 位系数
            let sevenTeenIndex = [7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2];
            // 截取参数前 17 位
            let front_seventeen = idcard.slice(0, 17);
            // 截取第 18 位
            let eighteen = idcard.slice(17, 18);
            // 这里如果是 X 要转换成小写,如果是数字在这里是字符串类型, 则转换成数字类型,好做判断
            eighteen = isNaN(parseInt(eighteen)) ? eighteen.toLowerCase() : parseInt(eighteen);
            // 定义一个变量计算系数乘积之和余数
            let remainder = 0;
            // 利用循环计算前 17 位数与系数乘积并添加到一个数组中
            // charAt()类似数组的访问下标一样,访问单个字符串的元素, 返回的是一个字符串因此要转换成数字
            for (let i = 0; i < 17; i++) {remainder = (remainder += parseInt(front_seventeen.charAt(i)) * sevenTeenIndex[i]) % 11;
            }
            // 余数对应数字数组
            let remainderKeyArr = [1, 0, 'X', 9, 8, 7, 6, 5, 4, 3, 2];
            // 取得余数对应的值
            let remainderKey = remainderKeyArr[remainder] === 'X' ? remainderKeyArr[remainder].toLowerCase() : remainderKeyArr[remainder];
            console.log(remainderKey);
            console.log(eighteen)
            // 如果最后一位数字对应上了余数所对应的值,则验证合格,否则不合格,
            // 由于不确定最后一个数字是否是大小写的 X,所以还是都转换成小写进行判断
            if (eighteen === remainderKey) {return idcard;} else {console.log('你输入的身份证号码格式不对!')
            }
        } else {console.log('你输入的身份证号码格式不对, 请重新输入!')
        }
    }
    // 函数调用
    validateIdCard('53010219200508011x');// 验证合格

正文完
 0