15位和18位身份证JS校验的简单实例


Posted in Javascript onJuly 18, 2016

一、身份证号码的结构和表示形式

1、号码的结构

根据〖中华人民共和国国家标准GB11643-1999〗中有关公民身份号码的规定,公民身份号码是特征组合码,由十七位数字本体码和一位校验码组成。排列顺序从左至右依次为:六位数字地址码,八位数字出生日期码,三位数字顺序码和一位数字校验码。

2、地址码

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

3、出生日期码

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

4、顺序码

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

5、校验码

(1)十七位数字本体码加权求和公式

S = Sum(Ai * Wi), i = 0, ... , 16 ,      先对前17位数字的权求和
Ai:表示第i位置上的身份证号码数字值
Wi:表示第i位置上的加权因子
7 9 10 5 8 4 2 1 6 3 7 9 10 5 8 4 2

(2)计算模

Y = mod(S, 11)

(3)通过模得到对应的校验码

Y: 0 1 2 3 4 5 6 7 8 9 10
校验码: 1 0 X 9 8 7 6 5 4 3 2
也就是说,如果得到余数为1则最后的校验位p应该为对应的0。

15位的号码:
a a b b c c y y m m d d x x s
18位的号码:
a a b b c c y y y y m m d d x x s p

二、地址码

身份证前6位为行政区划数字代码(简称数字码)说明(参考《GB/T 2260-2007 中华人民共和国行政区划代码》):该数字码的编制原则和结构分析,它采用三层六位层次码结构,按层次分别表示我国各省(自治区,直辖市,特别行政区)、市(地区,自治州,盟)、县(自治县、县级市、旗、自治旗、市辖区、林区、特区)。

(1)第1、2位数字:所在省份编码,表示省、自治区、直辖市、特别行政区。

省,直辖市代码表: { 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:"国外"} 

(2)第3、4位数字:所在省级市(县)编码,表示市、地区、自治州、盟、直辖市所辖市辖区、县汇总码、省(自治区)直辖县级行政区划汇总码。

——01~20、51~70表示市,直辖市则01表示市区,02以后表示直辖市辖区内的郊县;

——21~50表示地区、自治州、盟;

——90表示省(自治区)直辖县级行政区划汇总码。

(3)第5、6位数字:所在地级县(市)编码,表示县、自治县、县级市、旗、自治旗、市辖区、林区、特区。
——01~20表示市辖区、地区(自治州、盟)辖县级市、市辖特区以及省(自治区)直辖县级行政区划中的县级市,01通常表示辖区汇总码;

——21~80表示县、自治县、旗、自治旗、林区、地区辖特区;

——81~99表示省(自治区)辖县级市。

三、其它

15位身份证号码:

第7、8位为出生年份(两位数,用年份的后两位表示),
第9、10位为出生月份,
第11、12位代表出生日期,
第13、14位为顺序码,这个是随机数,
第15位代表性别,奇数为男,偶数为女。

18位身份证号码:

第7、8、9、10位为出生年份(四位数),
第11、12位为出生月份,
第13、14位代表出生日期,
第15、16位为顺序码,
第17位代表性别,奇数为男,偶数为女。
最后一位为校验位。

四、Js代码实例

var idCardNoUtil = {
 /*省,直辖市代码表*/
 provinceAndCitys: {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:"国外"},

 /*每位加权因子*/
 powers: ["7","9","10","5","8","4","2","1","6","3","7","9","10","5","8","4","2"],
 
 /*第18位校检码*/
 parityBit: ["1","0","X","9","8","7","6","5","4","3","2"],

 /*性别*/
 genders: {male:"男",female:"女"},

 /*校验地址码*/
 checkAddressCode: function(addressCode){
   var check = /^[1-9]\d{5}$/.test(addressCode);
   if(!check) return false;
   if(idCardNoUtil.provinceAndCitys[parseInt(addressCode.substring(0,2))]){
    return true;
   }else{
    return false;
   }
 },

 /*校验日期码*/
 checkBirthDayCode: function(birDayCode){
   var check = /^[1-9]\d{3}((0[1-9])|(1[0-2]))((0[1-9])|([1-2][0-9])|(3[0-1]))$/.test(birDayCode);
   if(!check) return false;  
   var yyyy = parseInt(birDayCode.substring(0,4),10);
   var mm = parseInt(birDayCode.substring(4,6),10);
   var dd = parseInt(birDayCode.substring(6),10);
  var xdata = new Date(yyyy,mm-1,dd);
  if(xdata > new Date()){
   return false;//生日不能大于当前日期
  }else if ( ( xdata.getFullYear() == yyyy ) && ( xdata.getMonth () == mm - 1 ) && ( xdata.getDate() == dd ) ){
   return true;
  }else{
   return false;
  }
 },
 
 /*计算校检码*/
 getParityBit: function(idCardNo){
  var id17 = idCardNo.substring(0,17);  
   /*加权 */
   var power = 0;
   for(var i=0;i<17;i++){
    power += parseInt(id17.charAt(i),10) * parseInt(idCardNoUtil.powers[i]);
   }       
   /*取模*/ 
   var mod = power % 11;
   return idCardNoUtil.parityBit[mod];
 },
 
 /*验证校检码*/
 checkParityBit: function(idCardNo){
   var parityBit = idCardNo.charAt(17).toUpperCase();
   if(idCardNoUtil.getParityBit(idCardNo) == parityBit){
     return true;
   }else{
     return false;
   }
 },

 /*校验15位或18位的身份证号码*/
 checkIdCardNo: function(idCardNo){
  //15位和18位身份证号码的基本校验
  var check = /^\d{15}|(\d{17}(\d|x|X))$/.test(idCardNo);
  if(!check) return false;
  //判断长度为15位或18位 
  if(idCardNo.length==15){
    return idCardNoUtil.check15IdCardNo(idCardNo);
  }else if(idCardNo.length==18){
    return idCardNoUtil.check18IdCardNo(idCardNo);
  }else{
    return false;
  }
 },

 //校验15位的身份证号码
 check15IdCardNo: function(idCardNo){
   //15位身份证号码的基本校验
   var check = /^[1-9]\d{7}((0[1-9])|(1[0-2]))((0[1-9])|([1-2][0-9])|(3[0-1]))\d{3}$/.test(idCardNo);  
   if(!check) return false;
   //校验地址码
   var addressCode = idCardNo.substring(0,6);
   check = idCardNoUtil.checkAddressCode(addressCode);
   if(!check) return false;
   var birDayCode = '19' + idCardNo.substring(6,12);
   //校验日期码
   return idCardNoUtil.checkBirthDayCode(birDayCode);
 },

 //校验18位的身份证号码
 check18IdCardNo: function(idCardNo){
   //18位身份证号码的基本格式校验
   var check = /^[1-9]\d{5}[1-9]\d{3}((0[1-9])|(1[0-2]))((0[1-9])|([1-2][0-9])|(3[0-1]))\d{3}(\d|x|X)$/.test(idCardNo);
   if(!check) return false;
   //校验地址码
   var addressCode = idCardNo.substring(0,6);
   check = idCardNoUtil.checkAddressCode(addressCode);
   if(!check) return false;
   //校验日期码
   var birDayCode = idCardNo.substring(6,14);
   check = idCardNoUtil.checkBirthDayCode(birDayCode);
   if(!check) return false;
   //验证校检码  
   return idCardNoUtil.checkParityBit(idCardNo);  
 },

 formateDateCN: function(day){
    var yyyy =day.substring(0,4);
    var mm = day.substring(4,6);
    var dd = day.substring(6);
    return yyyy + '-' + mm +'-' + dd;
 },

 //获取信息
 getIdCardInfo: function(idCardNo){
   var idCardInfo = {
    gender:"",  //性别
    birthday:"" // 出生日期(yyyy-mm-dd)
   };
  if(idCardNo.length==15){
    var aday = '19' + idCardNo.substring(6,12);
    idCardInfo.birthday=idCardNoUtil.formateDateCN(aday);
    if(parseInt(idCardNo.charAt(14))%2==0){
      idCardInfo.gender=idCardNoUtil.genders.female;
    }else{
      idCardInfo.gender=idCardNoUtil.genders.male;
    }   
  }else if(idCardNo.length==18){
    var aday = idCardNo.substring(6,14);
    idCardInfo.birthday=idCardNoUtil.formateDateCN(aday);
     if(parseInt(idCardNo.charAt(16))%2==0){
      idCardInfo.gender=idCardNoUtil.genders.female;
    }else{
      idCardInfo.gender=idCardNoUtil.genders.male;
    } 
    
  }
  return idCardInfo;
 },
 
 /*18位转15位*/
 getId15: function(idCardNo){
  if(idCardNo.length==15){
    return idCardNo;
  }else if(idCardNo.length==18){
    return idCardNo.substring(0,6) + idCardNo.substring(8,17); 
  }else{
  return null;
  }
 },
 
 /*15位转18位*/
 getId18: function(idCardNo){
  if(idCardNo.length==15){
    var id17 = idCardNo.substring(0,6) + '19' + idCardNo.substring(6);
    var parityBit = idCardNoUtil.getParityBit(id17);
    return id17 + parityBit;
  }else if(idCardNo.length==18){
    return idCardNo;
  }else{
  return null;
  }
 }
};

//身份证号码验证  
jQuery.validator.addMethod("idCardNo", function(value, element) { 
  return this.optional(element) || idCardNoUtil.checkIdCardNo(value); 
}, "Please specify a valid ID number."); 

//获取身份证信息 
var idCardInfo = idCardNoUtil.getIdCardInfo(idCardNo); 
alert(idCardInfo.gender + "|" + idCardInfo.birthday); 

注:录入并判断数据库中是否已存在同样的身份证时 
(1) 若输入的是15位的身份证:先查找15位的ID是否存在,若不存在还需要将15位的身份证转成18位的身份证,仍不存在的话才可录入系统。 
(2) 若输入的是18位的身份证:先查找18位的ID是否存在,若不存在还需要将18位的身份证转成15位的身份证,仍不存在的话才可录入系统。 
如果找到对应的15位身份证,需要将15位的更新到18位。

以上这篇15位和18位身份证JS校验的简单实例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
解决使用attachEvent函数时,this指向被绑定的元素的问题的方法
Aug 13 Javascript
JS Range HTML文档/文字内容选中、库及应用介绍
May 12 Javascript
Javascript图像处理—亮度对比度应用案例
Jan 03 Javascript
JS判定是否原生方法
Jul 22 Javascript
深入浅析javascript立即执行函数
Oct 23 Javascript
使用bat打开多个cmd窗口执行gulp、node
Feb 17 Javascript
详解React服务端渲染从入门到精通
Mar 28 Javascript
vue实现的上拉加载更多数据/分页功能示例
May 25 Javascript
vue和iview实现Scroll 数据无限滚动功能
Oct 31 Javascript
浅谈在vue-cli3项目中解决动态引入图片img404的问题
Aug 04 Javascript
Vue2.x和Vue3.x的双向绑定原理详解
Nov 05 Javascript
微信小程序实现加入购物车滑动轨迹
Nov 18 Javascript
Bootstrap零基础入门教程(二)
Jul 18 #Javascript
Bootstrap插件全集
Jul 18 #Javascript
全面了解javascript中的错误处理机制
Jul 18 #Javascript
JavaScript中ES6 Babel正确安装过程
Jul 18 #Javascript
深入理解JS正则表达式---分组
Jul 18 #Javascript
基于jQuery实现弹出可关闭遮罩提示框实例代码
Jul 18 #Javascript
简单的JS轮播图代码
Jul 18 #Javascript
You might like
轻松入门: 煮好咖啡的七个诀窍
2021/03/03 冲泡冲煮
php 短链接算法收集与分析
2011/12/30 PHP
解析如何通过PHP函数获取当前运行的环境 来进行判断执行逻辑(小技巧)
2013/06/25 PHP
php制作圆形用户头像的实例_自定义封装类源代码
2017/09/18 PHP
2014最热门的JavaScript代码高亮插件推荐
2014/11/25 Javascript
jQuery的load()方法及其回调函数用法实例
2015/03/25 Javascript
初步了解javascript面向对象
2015/11/09 Javascript
BootStrapValidator校验方式
2016/12/19 Javascript
JavaScript多线程运行库Nexus.js详解
2017/12/22 Javascript
angular2 ng2-file-upload上传示例代码
2018/08/23 Javascript
详解vuex commit保存数据技巧
2018/12/25 Javascript
微信小程序实现bindtap等事件传参
2019/04/08 Javascript
VUEX-action可以修改state吗
2019/11/19 Javascript
vue下axios拦截器token刷新机制的实例代码
2020/01/17 Javascript
vue实现员工信息录入功能
2020/06/11 Javascript
VSCode插件安装完成后的配置(常用配置)
2020/08/24 Javascript
python实现计算资源图标crc值的方法
2014/10/05 Python
Python嵌套列表转一维的方法(压平嵌套列表)
2018/07/03 Python
numpy数组之存取文件的实现示例
2019/05/24 Python
django框架使用orm实现批量更新数据的方法
2019/06/21 Python
12个步骤教你理解Python装饰器
2019/07/01 Python
Python中zip()函数的简单用法举例
2019/09/02 Python
Python实现语音识别和语音合成功能
2019/09/20 Python
Django实现简单网页弹出警告代码
2019/11/15 Python
基于python实现破解滑动验证码过程解析
2020/05/28 Python
利用Python pandas对Excel进行合并的方法示例
2020/11/04 Python
钉钉企业内部H5微应用开发详解
2020/05/12 HTML / CSS
以色列的身体护理及家居香薰品牌:Sabon NYC
2018/02/23 全球购物
澳大利亚婴儿、幼儿和儿童在线设计师商店:Smooch Baby
2019/02/16 全球购物
公务员职务工作的自我评价
2013/11/01 职场文书
学生出入校管理制度
2014/01/16 职场文书
《可爱的动物》教学反思
2014/02/22 职场文书
刊首寄语大全
2014/04/11 职场文书
村当支部个人对照检查材料思想汇报
2014/10/06 职场文书
实习生辞职信范文
2015/03/02 职场文书
后天观后感
2015/06/08 职场文书