前端技术分享-码匠 极客编程技术分享

您当前位于:JavaScript基础 ——> 正则 | 验证身份证号码正则的代码实例与讲解

正则 | 验证身份证号码正则的代码实例与讲解

2016/03/26 19:46:56 | 作者:HTML5学堂(码匠) | 分类:JavaScript基础 | 关键词:正则,验证,身份证号码

正则验证身份证号码

HTML5学堂:曾经一直觉得用正则验证身份证号码是很简单的~但是,当真正挖掘身份证号码的规则之后,才发现,想要写好一个正则验证也没有那么容易。最近一周利利出差,所以,只能周六跟大家一起分享一下自己的研究结果啦~

身份证的规则

书写一个正则之前,需要先了解一下身份证的基本规则

  1. /*
  2. * 身份证18位编码规则:dddddd yyyymmdd xxx y
  3. * dddddd:6位地区编码
  4. * yyyymmdd: 出生年(四位年)月日,如:19910215
  5. * xxx:顺序编码,系统产生,无法确定,奇数为男,偶数为女
  6. * y: 校验码,该位数值可通过前17位计算获得
  7. * HTML5学堂出品 http://www.h5course.com 请尊重原创
  8. * 前17位号码加权因子为 Wi = [ 7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2 ]
  9. * 验证位 Y = [ 1, 0, 10, 9, 8, 7, 6, 5, 4, 3, 2 ]
  10. * 如果验证码恰好是10,为了保证身份证是十八位,那么第十八位将用X来代替
  11. */

校验位计算方法:身份证前17位,每一位数字和相应位数的加权因子进行乘法运算,之后求和(17项之和),再用这个和对11取余,所得的余数作为“验证位数组Y”的下标,也就是Y[余数],找到“验证位数组Y”中的相应数字,如果身份证最后一位和这个数字吻合,则身份证号码合法(如果最后一位是X/x,就对应于“验证位数组Y”中的10这个数字)

简单的号码计算小例子

假如是这个身份证号码(这个身份证号码是我瞎编的):110203198811120342。

于是,复杂的计算开始了。取出身份证前17位,与[7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2]中对应的位分别进行乘法运算,于是乎:

sum = 1 * 7 + 1 * 9 + 0 * 10 + 2 * 5 + ... + 3 * 4 + 4 * 2。

我们能够计算出来,总和为177。之后用177对11取余,余数为1。那么在[1, 0, 10, 9, 8, 7, 6, 5, 4, 3, 2]数组中,下标为1的元素就是第二个元素,也就是数值为0。此时将0与身份证号的最后一位(2)做比较,很明显,错误,那么也证明了这个号码是我瞎编的了……

验证身份证号码的正则如何写?

身份证规则

我们将一个身份证号码拆开:身份证18位编码规则:dddddd yyyymmdd xxx y

1) dddddd:6位地区编码,地区编码没有以0开头的,举一个例子,北京用的就是110开头,河北用的就是130开头,福建省用的是350开头,此类。

2) yyyymmdd: 出生年(四位年)月日,前四位是年份,没啥可说的,月份只能是01~12,日期只能是01~31

3) xxx:三位数字

4) y: 校验码,0~9以及X(有时有人会写成x)

相对应的正则出炉喽

1) 地区编码:[1-9]\d{5}

2) 出生年份:[1-9]\d{3}

3) 出生月份:((0[1-9])|(1[0-2]))

4) 出生日期:((0[1-9])|([1-2]\d)|(3[0-1]))

5) 最后四位:((\d{4})|(\d{3}[Xx]))

完整匹配身份证号码的正则

于是乎,完整匹配身份证号码的正则华丽丽的诞生了~~~

  1. var reg = /^[1-9]\d{5}[1-9]\d{3}((0[1-9])|(1[0-2]))((0[1-9])|([1-2]\d)|(3[0-1]))((\d{4})|(\d{3}[Xx]))$/;

完了吗?别急,往下接着看~~~

使用JS增强号码的可控性

利利此处采用的是返回对象的设置方式,主要是便于获取完整的信息,需要注意的就是要在返回时提供比较合理的API了,不然对方是看不懂滴~~~

我们希望用户通过调用验证身份证号码的方法,不仅仅能够得到是否正确,还能够得到更加详细的信息。所以,一起先来看代码喽~

  1. /*
  2. * 功能:验证身份证是否可用,如果可用,则提取生日、性别等信息
  3. * 参数:传入一个字符串(建议不要采用数字,18位的数字会有精确度问题)
  4. * 返回:包含基本信息的对象
  5. * 作者:HTML5学堂 http://www.h5course.com
  6. */
  7. function regIDAllInf(str){
  8.     var str = str;
  9.     var reg = /^[1-9]\d{5}[1-9]\d{3}((0[1-9])|(1[0-2]))((0[1-9])|([1-2]\d)|(3[0-1]))((\d{4})|(\d{3}[Xx]))$/;
  10.     // 用于存储结果
  11.     var result = {};
  12.     if (reg.test(str)) {
  13.         var sum = 0;
  14.         var arrID = str.split("");
  15.         var arrWi = [7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2];
  16.         var arrY = [1, 0, 10, 9, 8, 7, 6, 5, 4, 3, 2];
  17.         for (var i = 0; i < arrWi.length; i++) {
  18.             sum += arrID[i] * arrWi[i];
  19.         };
  20.         sum %= 11;
  21.         var lastID = arrID[arrID.length - 1];
  22.         if (lastID == "X" || lastID == "x") {
  23.             lastID = 10;
  24.         };
  25.         if (arrY[sum] == lastID) {
  26.             result["check"] = true;
  27.             result["birthday"] = str.substr(6, 8);
  28.             result["cityCode"] = str.substr(0, 6);
  29.             result["gender"] = (str.substr(14, 3) % 2 == 0) ? "女" : "男";
  30.         } else {
  31.             result["check"] = false;
  32.             result["error"] = "身份证号码输入错误";
  33.         }
  34.     } else {
  35.         result["check"] = false;
  36.         result["error"] = "身份证号码格式有误";
  37.     }    
  38.     return result;
  39. }
  40. console.log(regIDAllInf(str)); // 此处请将str替换为身份证号码进行测试

如果格式正确,会返回匹配正确,并返回性别、区域、生日的信息。如果错误,也会根据情况返回不同的错误提示信息。
PS:注意,此处请传递字符串类型,不要传递数字类型,首先有些人的身份证号码会带有X,其次,JS能够处理的数字位数有限~!

本文章内容小编:HTML5学堂-利利。耗时4h~

欢迎沟通交流~HTML5学堂

微信公众号,HTML5学堂,码匠,原创文章,WEB前端,技术分享

HTML5学堂

原创前端技术分享

HTML5学堂,HTML5,WEB,前端,视频课程,技术视频,学习视频,面试,JS

原创视频课程

用心打造精品课程

微信小程序,决胜前端,面试题,面试题集合,前端,HTML5,真题

小程序-决胜前端

前端面试题宝库

原创书籍,学习书籍,书籍推荐,HTML5布局之路,HTML5,WEB前端

HTML5布局之路

非传统模式讲解前端