为了正常的体验网站,请在浏览器设置里面开启Javascript功能!

身份证验证算法

2018-01-31 3页 doc 15KB 31阅读

用户头像

is_014457

暂无简介

举报
身份证验证算法身份证验证算法 根据〖中华人民共和国国家标准GB 11643-1999〗中有关公民身份号码的规定,公民身份号码是特征组合码,由十七位数字本体码和一位数字校验码组成。排列顺序从左至右依次为:六位数字地址码,八位数字出生日期码,三位数字顺序码和一位数字校验码。 地址码表示编码对象常住户口所在县(市、旗、区)的行政区划代码。生日期码表示编码对象出生的年、月、日,其中年份用四位数字表示,年、月、日之间不用分隔符。顺序码表示同一地址码所标识的区域范围内,对同年、月、日出生的人员编定的顺序号。顺序码的奇数分给男性,偶数分给女性。校验码...
身份证验证算法
身份证验证算法 根据〖中华人民共和国国家标准GB 11643-1999〗中有关公民身份号码的规定,公民身份号码是特征组合码,由十七位数字本体码和一位数字校验码组成。排列顺序从左至右依次为:六位数字地址码,八位数字出生日期码,三位数字顺序码和一位数字校验码。 地址码表示编码对象常住户口所在县(市、旗、区)的行政区划代码。生日期码表示编码对象出生的年、月、日,其中年份用四位数字表示,年、月、日之间不用分隔符。顺序码表示同一地址码所标识的区域范围内,对同年、月、日出生的人员编定的顺序号。顺序码的奇数分给男性,偶数分给女性。校验码是根据前面十七位数字码,按照ISO 7064:1983.MOD 11-2校验码计算出来的检验码。下面举例说明该计算方法。 15位的身份证编码首先把出生年扩展为4位,简单的就是增加一个19,但是这对于1900年出生的人不使用(这样的寿星不多了) 某男性公民身份号码本体码为34052419800101001,首先按照公式?计算: ?(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 98 76 54 32 1 ai 34 05 24 19 80 01 01 00 1a1 Wi 79 10 58 42 16 37 910 58 42 1 ai×Wi 21 36 025 16 16 29 48 00 90 50 02 a1 根据公式(1)进行计算: ?(ai×Wi)=(21+36+0+25+16+16+2+9+48++0+0+9+0+5+0+0+2)=189 189?11=17+2/11 ?(ai×Wi)(mod 11)=2 然后根据计算的结果,从下面的表中查出相应的校验码,其中X表示计算结果为10: ?(ai×WI)(mod 11)0 12 34 56 78 910 校验码字符值ai 10 X9 87 65 43 2 根据上表,查出计算结果为2的校验码为所以该人员的公民身份号码应该为34052419800101001 X。 校验代码: var aCity={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 iSum=0;var info="";if(sId=="")return true;if(~ /^\d{17}(\d|x)$/i.test(sId))return false;sId=sId.replace(/x$/i,"a");if(aCity[parseInt(sId.substr(0,2))]==null)return false; sBirthday=sId.substr(6,4)+"-"+Number(sId.substr(10,2))+"- "+Number(sId.substr(12,2));var d=new Date(sBirthday.replace(/- /g,"/"));if(sBirthday~=(d.getFullYear()+"-"+(d.getMonth()+1)+"- "+d.getDate()))return false;for(var i=17;i=0;i-- )iSum+=(Math.pow(2,i)%11)*parseInt(sId.charAt(17-i),11);if(iSum%11~=1)return false;return true; 作者:绿水青山发表于2010-12-11 14:55原文链接 评论:0查看评论发表评论 最新新闻: 12-11 14:55) ?移动电子商务时代的到来(2010- ?仪表盘式的时钟-Geek专用(2010-12-11 14:54) ?游戏开发商Rovio推游戏内付费平台(2010-12-11 14:50) ?什么样的社会化信号才是Google&Bing真正认为有价值的?(2010-12-11 14:49) ?谷歌牵动"电子书大爆炸"(2010-12-11 14:43) 编辑推荐:iPhone的诞生故事 网站导航:博客园首页我的园子新闻闪存小组博问知识库
/
本文档为【身份证验证算法】,请使用软件OFFICE或WPS软件打开。作品中的文字与图均可以修改和编辑, 图片更改请在作品中右键图片并更换,文字修改请直接点击文字进行修改,也可以新增和删除文档中的内容。
[版权声明] 本站所有资料为用户分享产生,若发现您的权利被侵害,请联系客服邮件isharekefu@iask.cn,我们尽快处理。 本作品所展示的图片、画像、字体、音乐的版权可能需版权方额外授权,请谨慎使用。 网站提供的党政主题相关内容(国旗、国徽、党徽..)目的在于配合国家政策宣传,仅限个人学习分享使用,禁止用于任何广告和商用目的。

历史搜索

    清空历史搜索