js实现二代身份证号码验证详解


Posted in Javascript onNovember 20, 2014

废话少说,直接上代码,注释里解析的很清楚了,这里就不BB了。

/*

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

 地址码表示编码对象常住户口所在县(市、旗、区)的行政区划代码。

 出生日期码表示编码对象出生的年、月、日,其中年份用四位数字表示,年、月、日之间不用分隔符。

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

 校验码是根据前面十七位数字码,按照ISO 7064:1983.MOD 11-2校验码计算出来的检验码。

 

出生日期计算方法。

位的身份证编码首先把出生年扩展为4位,简单的就是增加一个19或18,这样就包含了所有1800-1999年出生的人;

年后出生的肯定都是18位的了没有这个烦恼,至于1800年前出生的,那啥那时应该还没身份证号这个东东,⊙?⊙b汗...

下面是正则表达式:

 出生日期1800-2099 (18|19|20)?\d{2}(0[1-9]|1[12])(0[1-9]|[12]\d|3[01])

 身份证正则表达式 /^\d{6}(18|19|20)?\d{2}(0[1-9]|1[12])(0[1-9]|[12]\d|3[01])\d{3}(\d|X)$/i 

位校验规则 6位地址编码+6位出生日期+3位顺序号

位校验规则 6位地址编码+8位出生日期+3位顺序号+1位校验位

 

校验位规则 公式:∑(ai×Wi)(mod 11)……………………………………(1)

公式(1)中: 

i----表示号码字符从由至左包括校验码在内的位置序号; 

ai----表示第i位置上的号码字符值; 

Wi----示第i位置上的加权因子,其数值依据公式Wi=2^(n-1)(mod 11)计算得出。

i 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1

 Wi 7 9 10 5 8 4 2 1 6 3 7 9 10 5 8 4 2 1

 

*/

//身份证号合法性验证 

//支持15位和18位身份证号

//支持地址编码、出生日期、校验位验证

function IdentityCodeValid(code) { 

var city={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:"国外 "};

var tip = "";

 var pass= true;
 if(!code || !/^\d{6}(18|19|20)?\d{2}(0[1-9]|1[12])(0[1-9]|[12]\d|3[01])\d{3}(\d|X)$/i.test(code)){

 tip = "身份证号格式错误";

pass = false;

 }
 else if(!city[code.substr(0,2)]){

 tip = "地址编码错误";

pass = false;

 }

 else{

 //18位身份证需要验证最后一位校验位

if(code.length == 18){

 code = code.split('');

 //∑(ai×Wi)(mod 11)

 //加权因子

var factor = [ 7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2 ];

 //校验位

var parity = [ 1, 0, 'X', 9, 8, 7, 6, 5, 4, 3, 2 ];

 var sum = 0;

 var ai = 0;

 var wi = 0;

 for (var i = 0; i < 17; i++)

 {

 ai = code[i];

 wi = factor[i];

 sum += ai * wi;

 }

 var last = parity[sum % 11];

 if(parity[sum % 11] != code[17]){

 tip = "校验位错误";

pass =false;

 }

 }

 }

 if(!pass) alert(tip);

 return pass;

 }

 var c = '130981199312253466';

 var res= IdentityCodeValid(c);

怎么样,非常全面第一个身份证号码验证代码吧,和网上搜来的其他验证代码简直不是一个次元的,小伙伴们需要的直接拿走用吧。

Javascript 相关文章推荐
让人期待的2011年度最佳 jQuery 插件分享
Mar 16 Javascript
JavaScript面向对象知识串结(读JavaScript高级程序设计(第三版))
Jul 17 Javascript
浅析JQuery UI Dialog的样式设置问题
Dec 18 Javascript
11种ASP连接数据库的方法
Sep 18 Javascript
全面了解JavaScript对象进阶
Jul 19 Javascript
Vue中父组件向子组件通信的方法
Jul 11 Javascript
Vue项目webpack打包部署到Tomcat刷新报404错误问题的解决方案
May 15 Javascript
vue+element UI实现树形表格带复选框的示例代码
Apr 16 Javascript
使用 vue 实现灭霸打响指英雄消失的效果附demo
May 06 Javascript
JavaScript(js)处理的HTML事件、键盘事件、鼠标事件简单示例
Nov 19 Javascript
three.js中多线程的使用及性能测试详解
Jan 07 Javascript
vue 中 get / delete 传递数组参数方法
Mar 23 Vue.js
js实现网页标题栏闪烁提示效果实例分析
Nov 20 #Javascript
javascript获取flash版本号的方法
Nov 20 #Javascript
Jquery对象和Dom对象的区别分析
Nov 20 #Javascript
深入理解javascript变量声明
Nov 20 #Javascript
javascript限制用户只能输汉字中文的方法
Nov 20 #Javascript
jQuery 中$(this).index与$.each的使用指南
Nov 20 #Javascript
jQuery提示效果代码分享
Nov 20 #Javascript
You might like
相对路径转化成绝对路径
2007/04/10 PHP
php从文件夹随机读取文件的方法
2015/06/01 PHP
php结合ajax实现手机发红包的案例
2016/10/13 PHP
PHP实现双链表删除与插入节点的方法示例
2017/11/11 PHP
PHP实现数组转JSon和JSon转数组的方法示例
2018/06/14 PHP
javascript web页面刷新的方法收集
2009/07/02 Javascript
JavaScript 原型学习总结
2010/10/29 Javascript
jQuery ajax serialize()方法的使用以及常见问题解决
2013/01/27 Javascript
JavaScript表达式:URL 协议介绍
2013/03/10 Javascript
详解Javascript 装载和执行
2014/11/17 Javascript
JavaScript中定义函数的三种方法
2015/03/12 Javascript
简单学习JavaScript中的for语句循环结构
2015/11/10 Javascript
jquery.qtip提示信息插件用法简单实例
2016/06/17 Javascript
JSON对象 详解及实例代码
2016/10/18 Javascript
本地存储localStorage用法详解
2017/07/31 Javascript
快速理解 JavaScript 中的 LHS 和 RHS 查询的用法
2017/08/24 Javascript
微信小程序开发之路由切换页面重定向问题
2018/09/18 Javascript
说说如何使用Vuex进行状态管理(小结)
2019/04/14 Javascript
vue中使用vue-cli接入融云实现即时通信
2019/04/19 Javascript
微信小程序实现多选框全选与取消全选功能示例
2019/05/14 Javascript
微信JSSDK实现打开摄像头拍照再将相片保存到服务器
2019/11/15 Javascript
webpack常用构建优化策略小结
2019/11/21 Javascript
Python实现的计数排序算法示例
2017/11/29 Python
python实现猜单词小游戏
2020/05/22 Python
python模拟登陆,用session维持回话的实例
2018/12/27 Python
Python集中化管理平台Ansible介绍与YAML简介
2019/06/12 Python
pandas计算最大连续间隔的方法
2019/07/04 Python
Molton Brown美国官网:奢华美容、香水、沐浴和身体护理
2020/09/02 全球购物
七年级数学教学反思
2014/01/22 职场文书
《陋室铭》教学反思
2014/02/26 职场文书
国旗下演讲稿
2014/05/08 职场文书
村居抓节水倡议书
2014/05/19 职场文书
关于感恩的演讲稿400字
2014/08/26 职场文书
文员岗位职责
2015/02/04 职场文书
大学生读书笔记范文
2015/07/01 职场文书
安全生产标语口号
2015/12/26 职场文书