js验证身份证号码记录的方法


Posted in Javascript onApril 26, 2019

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

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');//验证合格

总结

以上所述是小编给大家介绍的js验证身份证号码记录的方法,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!

Javascript 相关文章推荐
Mootools 1.2教程 输入过滤第一部分(数字)
Sep 15 Javascript
Jquery 最近浏览过的商品的功能实现代码
May 14 Javascript
JQuery对checkbox操作 (循环获取)
May 20 Javascript
jQuery EasyUI API 中文文档 - Pagination分页
Sep 29 Javascript
jQuery 阴影插件代码分享
Jan 09 Javascript
JS.GetAllChild(element,deep,condition)使用介绍
Sep 21 Javascript
JQuery使用$.ajax和checkbox实现下次不在通知功能
Apr 16 Javascript
jQuery动态效果显示人物结构关系图的方法
May 07 Javascript
IE浏览器下PNG相关功能
Jul 05 Javascript
前端性能优化及技巧
May 06 Javascript
JS实现直接运行html代码的方法
Mar 13 Javascript
微信小程序非swiper组件实现的自定义伪3D轮播图效果示例
Dec 11 Javascript
详解VScode编辑器vue环境搭建所遇问题解决方案
Apr 26 #Javascript
react高阶组件添加和删除props
Apr 26 #Javascript
详解微信小程序-canvas绘制文字实现自动换行
Apr 26 #Javascript
vue 进阶之实现父子组件间的传值
Apr 26 #Javascript
详解JS判断页面是在手机端还是在PC端打开的方法
Apr 26 #Javascript
配置一个vue3.0项目的完整步骤
Apr 26 #Javascript
关于Vue源码vm.$watch()内部原理详解
Apr 26 #Javascript
You might like
PHP向socket服务器收发数据的方法
2015/01/24 PHP
php 解析xml 的四种方法详细介绍
2016/10/26 PHP
PHP基于迭代实现文件夹复制、删除、查看大小等操作的方法
2017/08/11 PHP
TP5框架实现签到功能的方法分析
2020/04/05 PHP
Java 正则表达式学习总结和一些小例子
2012/09/13 Javascript
js中 关于undefined和null的区别介绍
2013/04/16 Javascript
JavaScript获取当前运行脚本文件所在目录的方法
2016/02/03 Javascript
angularjs+bootstrap菜单的使用示例代码
2017/03/07 Javascript
React中使用collections时key的重要性详解
2017/08/07 Javascript
JavaScript中各数制转换全面总结
2017/08/21 Javascript
微信小程序之数据缓存的实例详解
2017/09/29 Javascript
解决在Bootstrap模糊框中使用WebUploader的问题
2018/03/22 Javascript
微信小程序如何获取群聊的openGid以及名称详解
2019/07/17 Javascript
微信小程序HTTP请求从0到1封装
2019/09/09 Javascript
vue 中固定导航栏的实例代码
2019/11/01 Javascript
javascript实现移动端红包雨页面
2020/06/23 Javascript
TypeScript 运行时类型检查补充工具
2020/09/28 Javascript
Python中max函数用法实例分析
2015/07/17 Python
python装饰器-限制函数调用次数的方法(10s调用一次)
2018/04/21 Python
python实现windows下文件备份脚本
2018/05/27 Python
Django url,从一个页面调到另个页面的方法
2019/08/21 Python
pytorch nn.Conv2d()中的padding以及输出大小方式
2020/01/10 Python
python3 字符串知识点学习笔记
2020/02/08 Python
python实现引用其他路径包里面的模块
2020/03/09 Python
PyCharm 2020 激活到 2100 年的教程
2020/03/25 Python
解决pytorch 交叉熵损失输出为负数的问题
2020/07/07 Python
纯CSS3编写的的精美动画进度条(无flash/无图像/无脚本/附源码)
2013/01/07 HTML / CSS
测量实习生自我鉴定
2013/09/19 职场文书
土木工程应届生求职信
2013/10/31 职场文书
应届生新闻编辑求职信
2013/11/19 职场文书
中医临床专业自我鉴定范文
2014/01/15 职场文书
理想演讲稿范文
2014/05/21 职场文书
2014最新股权信托合同协议书
2014/11/18 职场文书
门店店长岗位职责
2015/04/14 职场文书
2016十一国庆节感言
2015/12/09 职场文书
python 实现图片特效处理
2022/04/03 Python