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 相关文章推荐
jquery 最简单易用的表单验证插件
Feb 27 Javascript
JavaScript字符串String和Array操作的有趣方法
Dec 18 Javascript
在页面上用action传递参数到后台出现乱码的解决方法
Dec 31 Javascript
javascript中基本类型和引用类型的区别分析
May 12 Javascript
深入分析JSON编码格式提交表单数据
Jun 25 Javascript
jQuery插件实现多级联动菜单效果
Dec 01 Javascript
JS实现浏览器打印、打印预览示例
Feb 28 Javascript
JavaScript运动框架 多物体任意值运动(三)
May 17 Javascript
Angularjs在360兼容模式下取数据缓存问题的解决办法
Jun 22 Javascript
zTree获取当前节点的下一级子节点数实例
Sep 05 Javascript
vue 动态绑定背景图片的方法
Aug 10 Javascript
react使用CSS实现react动画功能示例
May 18 Javascript
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
PHP 函数执行效率的小比较
2010/10/17 PHP
PHP+MYSQL会员系统的开发实例教程
2014/08/23 PHP
Laravel 框架路由原理与路由访问实例分析
2020/04/14 PHP
一个js封装的不错的选项卡效果代码
2008/02/15 Javascript
一个JavaScript的求爱小特效
2014/05/09 Javascript
node.js中的buffer.write方法使用说明
2014/12/10 Javascript
javascript截取字符串小结
2015/04/28 Javascript
JavaScript数组操作详解
2017/02/04 Javascript
js从输入框读取内容,比较两个数字的大小方法
2017/03/13 Javascript
微信小程序实现根据字母选择城市功能
2017/08/16 Javascript
Angular2整合其他插件的方法
2018/01/20 Javascript
ES6 fetch函数与后台交互实现
2018/11/14 Javascript
Vue防止白屏添加首屏动画的实例
2019/10/31 Javascript
electron 如何将任意资源打包的方法步骤
2020/04/16 Javascript
[48:24]完美世界DOTA2联赛循环赛LBZS vs Forest 第一场 10月30日
2020/10/31 DOTA
Python用户推荐系统曼哈顿算法实现完整代码
2017/12/01 Python
Python zip()函数用法实例分析
2018/03/17 Python
python+selenium实现自动抢票功能实例代码
2018/11/23 Python
对python 读取线的shp文件实例详解
2018/12/22 Python
Python进阶之自定义对象实现切片功能
2019/01/07 Python
Django多数据库的实现过程详解
2019/08/01 Python
Python脚本破解压缩文件口令实例教程(zipfile)
2020/06/14 Python
Python如何在windows环境安装pip及rarfile
2020/06/15 Python
Python项目打包成二进制的方法
2020/12/30 Python
分享30个新鲜的CSS3打造的精美绚丽效果(附演示下载)
2012/12/28 HTML / CSS
世界上最值得信赖的多日游在线市场:TourRadar
2018/07/20 全球购物
自荐书4要点
2014/01/25 职场文书
幼儿教师国培感言
2014/02/19 职场文书
小区物业门卫岗位职责
2014/04/10 职场文书
港澳通行证委托书怎么写
2014/08/02 职场文书
师德师风个人整改措施
2014/10/27 职场文书
群众路线教育实践活动学习笔记
2014/11/05 职场文书
辞职信怎么写
2015/02/27 职场文书
施工安全保证书
2015/05/09 职场文书
人与自然观后感
2015/06/16 职场文书
参观监狱警示教育心得体会
2016/01/15 职场文书