超精准的javascript验证身份证号的具体实现方法


Posted in Javascript onNovember 18, 2015

编写程序前先来了解下身份证号的构成:

身份证号分为两种,旧的为15位,新的为18位。

身份证15位编码规则:dddddd yymmdd xx p   

其中 dddddd:地区码    yymmdd: 出生年月日    xx: 顺序类编码,无法确定    p: 性别,奇数为男,偶数为女;

身份证18位编码规则:dddddd yyyymmdd xxx y   

其中 dddddd:地区码    yyyymmdd: 出生年月日     xxx:顺序类编码,无法确定,奇数为男,偶数为女    y: 校验码,该位数值可通过前17位计算获得,计算的公式见程序,一些需要用到的常数

18位号码加权因子为(从右到左) Wi = [ 7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2,1 ]    验证位 Y = [ 1, 0, 10, 9, 8, 7, 6, 5, 4, 3, 2 ]    校验位计算公式:Y_P = mod( ∑(Ai×Wi),11 )    

i为身份证号码从右往左数的 2...18 位; Y_P为脚丫校验码所在校验码数组位置。

var Wi = [ 7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2, 1 ]; // 加权因子 
var ValideCode = [ 1, 0, 10, 9, 8, 7, 6, 5, 4, 3, 2 ];   // 身份证验证位值.10代表X 
function IdCardValidate(idCard) { 
 idCard = trim(idCard.replace(/ /g, ""));    //去掉字符串头尾空格      
 if (idCard.length == 15) { 
  return isValidityBrithBy15IdCard(idCard);  //进行15位身份证的验证 
 } else if (idCard.length == 18) { 
  var a_idCard = idCard.split("");    // 得到身份证数组 
  if(isValidityBrithBy18IdCard(idCard)&&isTrueValidateCodeBy18IdCard(a_idCard)){ //进行18位身份证的基本验证和第18位的验证
   return true; 
  }else { 
   return false; 
  } 
 } else { 
  return false; 
 } 
} 
/** 
 * 判断身份证号码为18位时最后的验证位是否正确 
 * @param a_idCard 身份证号码数组 
 * @return 
 */ 
function isTrueValidateCodeBy18IdCard(a_idCard) { 
 var sum = 0;        // 声明加权求和变量 
 if (a_idCard[17].toLowerCase() == 'x') { 
  a_idCard[17] = 10;     // 将最后位为x的验证码替换为10方便后续操作 
 } 
 for ( var i = 0; i < 17; i++) { 
  sum += Wi[i] * a_idCard[i];   // 加权求和 
 } 
 valCodePosition = sum % 11;    // 得到验证码所位置 
 if (a_idCard[17] == ValideCode[valCodePosition]) { 
  return true; 
 } else { 
  return false; 
 } 
} 
/** 
 * 验证18位数身份证号码中的生日是否是有效生日 
 * @param idCard 18位书身份证字符串 
 * @return 
 */ 
function isValidityBrithBy18IdCard(idCard18){ 
 var year = idCard18.substring(6,10); 
 var month = idCard18.substring(10,12); 
 var day = idCard18.substring(12,14); 
 var temp_date = new Date(year,parseFloat(month)-1,parseFloat(day)); 
 // 这里用getFullYear()获取年份,避免千年虫问题 
 if(temp_date.getFullYear()!=parseFloat(year) 
   ||temp_date.getMonth()!=parseFloat(month)-1 
   ||temp_date.getDate()!=parseFloat(day)){ 
   return false; 
 }else{ 
  return true; 
 } 
} 
 /** 
 * 验证15位数身份证号码中的生日是否是有效生日 
 * @param idCard15 15位书身份证字符串 
 * @return 
 */ 
 function isValidityBrithBy15IdCard(idCard15){ 
  var year = idCard15.substring(6,8); 
  var month = idCard15.substring(8,10); 
  var day = idCard15.substring(10,12); 
  var temp_date = new Date(year,parseFloat(month)-1,parseFloat(day)); 
  // 对于老身份证中的你年龄则不需考虑千年虫问题而使用getYear()方法 
  if(temp_date.getYear()!=parseFloat(year) 
    ||temp_date.getMonth()!=parseFloat(month)-1 
    ||temp_date.getDate()!=parseFloat(day)){ 
    return false; 
  }else{ 
   return true; 
  } 
 } 
//去掉字符串头尾空格 
function trim(str) { 
 return str.replace(/(^\s*)|(\s*$)/g, ""); 
}

 根据身份证号对其进行性别的判定

/** 
 * 通过身份证判断是男是女 
 * @param idCard 15/18位身份证号码 
 * @return 'female'-女、'male'-男 
 */ 
function maleOrFemalByIdCard(idCard){ 
 idCard = trim(idCard.replace(/ /g, ""));  // 对身份证号码做处理。包括字符间有空格。 
 if(idCard.length==15){ 
  if(idCard.substring(14,15)%2==0){ 
   return 'female'; 
  }else{ 
   return 'male'; 
  } 
 }else if(idCard.length ==18){ 
  if(idCard.substring(14,17)%2==0){ 
   return 'female'; 
  }else{ 
   return 'male'; 
  } 
 }else{ 
  return null; 
 } 
}

以上就是javascript验证身份证号的具体实现方法,并且根据身份证能验证性别,是不是很神奇,欢迎大家学习借鉴。

Javascript 相关文章推荐
学习ExtJS(二) Button常用方法
Oct 07 Javascript
JS getMonth()日期函数的值域是0-11
Feb 15 Javascript
JavaScript 语言的递归编程
May 18 Javascript
JS基于cookie实现来宾统计记录访客信息的方法
Aug 04 Javascript
jquery实现的判断倒计时是否结束代码
Feb 05 Javascript
通过正则表达式获取url中参数的简单实现
Jun 07 Javascript
vue中使用refs定位dom出现undefined的解决方法
Dec 21 Javascript
jQuery实现百度图片移入移出内容提示框上下左右移动的效果
Jun 05 jQuery
浅谈微信JS-SDK 微信分享接口开发(介绍版)
Aug 15 Javascript
微信公众号生成新浪短网址的实现(快速生成)
Aug 18 Javascript
JavaScript对象原型链原理解析
Jan 22 Javascript
Vue实现移动端拖拽交换位置
Jul 29 Javascript
javascript中checkbox使用方法简单实例演示
Nov 17 #Javascript
javascript下拉列表中显示树形菜单的实现方法
Nov 17 #Javascript
JS封装cookie操作函数实例(设置、读取、删除)
Nov 17 #Javascript
jquery可定制的在线UEditor编辑器
Nov 17 #Javascript
JS实现选项卡实例详解
Nov 17 #Javascript
基于Jquery代码实现支持PC端手机端幻灯片代码
Nov 17 #Javascript
举例说明如何为JavaScript的方法参数设置默认值
Nov 17 #Javascript
You might like
PHP中获取内网用户MAC地址(WINDOWS/linux)的实现代码
2011/08/11 PHP
如何使用php输出时间格式
2013/08/31 PHP
php获取目标函数执行时间示例
2014/03/04 PHP
php实现文章置顶功能的方法
2016/10/20 PHP
form表单传递数组数据、php脚本接收的实例
2017/02/09 PHP
php 从指定数字中获取随机组合的简单方法(推荐)
2017/04/05 PHP
解决php-fpm.service not found问题的办法
2017/06/06 PHP
PHP PDOStatement::debugDumpParams讲解
2019/01/30 PHP
jquery validation插件表单验证的一个例子
2010/03/03 Javascript
jQuery实现可拖动的浮动层完整代码
2013/05/27 Javascript
JQuery处理json与ajax返回JSON实例代码
2014/01/03 Javascript
Javascript中Array.prototype.map()详解
2014/10/22 Javascript
JS+CSS实现六级网站导航主菜单效果
2015/09/28 Javascript
跟我学习javascript解决异步编程异常方案
2015/11/23 Javascript
jQuery图片渐变特效的简单实现
2016/06/25 Javascript
微信支付 JS API支付接口详解
2016/07/11 Javascript
在微信小程序中渲染HTML内容的方法示例
2018/09/28 Javascript
Vue CLI 3.x 自动部署项目至服务器的方法
2019/04/02 Javascript
基于JQuery和DWR实现异步数据传递
2020/10/16 jQuery
利用 JavaScript 实现并发控制的示例代码
2020/12/31 Javascript
python使用psutil模块获取系统状态
2016/08/27 Python
Python实现图片转字符画的示例
2017/08/22 Python
python编写Logistic逻辑回归
2020/12/30 Python
Python根据文件名批量转移图片的方法
2018/10/21 Python
解决django xadmin主题不显示和只显示bootstrap2的问题
2020/03/30 Python
django项目中使用云片网发送短信验证码的实现
2021/01/19 Python
数控技术应届生求职信
2013/11/13 职场文书
结婚周年感言
2014/02/24 职场文书
软件部经理岗位职责范本
2014/02/25 职场文书
观看《永远的雷锋》心得体会
2014/03/12 职场文书
高中毕业生登记表自我鉴定范文
2014/03/18 职场文书
第二批党的群众路线教育实践活动总结报告
2014/10/30 职场文书
世界地球日活动总结
2015/02/09 职场文书
图解排序算法之希尔排序Java实现
2021/06/26 Java/Android
Python快速实现一键抠图功能的全过程
2021/06/29 Python
mysq启动失败问题及场景分析
2021/07/15 MySQL