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

 更新时间:2016年07月18日 10:06:48   投稿:jingxian   我要评论
下面小编就为大家带来一篇15位和18位身份证JS校验的简单实例。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧

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

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校验的简单实例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持澳门金沙网上娱乐。

相关文章

  • 实现连缀调用的map方法(prototype)

    实现连缀调用的map方法(prototype)

    实现连缀调用的map方法(prototype),需要学习的朋友可以参考下。
    2009-08-08
  • JS简单随机数生成方法

    JS简单随机数生成方法

    这篇文章主要介绍了JS简单随机数生成方法,通过javascript自定义函数演示了随机数的生成方法,需要的朋友可以参考下
    2016-09-09
  • javascript实现数字倒计时特效

    javascript实现数字倒计时特效

    这篇文章主要介绍了javascript实现网页倒计时数字时钟效果,是一款非常实用的javascript倒计时特效,具有一定参考借鉴价值,需要的朋友可以参考下
    2016-03-03
  • JavaScript实现Iterator模式实例分析

    JavaScript实现Iterator模式实例分析

    这篇文章主要介绍了JavaScript实现Iterator模式,实例分析了Iterator模式的相关实现技巧,需要的朋友可以参考下
    2015-06-06
  • 轻松5句话解决JavaScript的作用域

    轻松5句话解决JavaScript的作用域

    作用域(scope)是javascript语言的基石之一,在构建复杂程序时可能是最头痛的东西,所以这里罗列了五句话轻松搞定并且附上了示例。给需要的朋友参考学习。
    2016-07-07
  • BootStrapTable服务器分页实例解析

    BootStrapTable服务器分页实例解析

    项目中经常会使用到表格,数据量大的时候还需要进行分页,项目设计阶段,我选择了bootstrapTable的js插件,个人觉得这个框架非常好用,支持服务器端分页,此篇主要写的主要是关于服务器分页,需要的朋友可以参考下
    2016-12-12
  • js事件源window.event.srcElement兼容性写法(详解)

    js事件源window.event.srcElement兼容性写法(详解)

    下面小编就为大家带来一篇js事件源window.event.srcElement兼容性写法(详解)。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2016-11-11
  • js实现页面多个日期时间倒计时效果

    js实现页面多个日期时间倒计时效果

    这篇文章主要为大家详细介绍了js实现页面多个日期时间倒计时效果,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-06-06
  • 微信小程序JS加载esmap地图的实例详解

    微信小程序JS加载esmap地图的实例详解

    这篇文章主要介绍了微信小程序JS加载esmap地图的实例代码,代码简单易懂,非常不错,具有一定的参考借鉴价值,需要的朋友可以参考下
    2019-09-09
  • JS小功能(button选择颜色)简单实例

    JS小功能(button选择颜色)简单实例

    这篇文章主要介绍了button选择颜色简单实例,有需要的朋友可以参考一下
    2013-11-11

最新评论