18位身份证号码校验位规则

18位身份证号码校验位规则

ID:19416229

大小:29.50 KB

页数:8页

时间:2018-10-02

18位身份证号码校验位规则_第1页
18位身份证号码校验位规则_第2页
18位身份证号码校验位规则_第3页
18位身份证号码校验位规则_第4页
18位身份证号码校验位规则_第5页
资源描述:

《18位身份证号码校验位规则》由会员上传分享,免费在线阅读,更多相关内容在应用文档-天天文库

1、18位身份证号码校验位规则18位身份证号码校验位规则2009/01/1115:33根据〖中华人民共和国国家标准GB11643-1999〗中有关公民身份号码的规定,公民身份号码是特征组合码,由十七位数字本体码和一位数字校验码组成。排列顺序从左至右依次为:六位数字地址码,八位数字出生日期码,三位数字顺序码和一位数字校验码。地址码表示编码对象常住户口所在县(市、旗、区)的行政区划代码。生日期码表示编码对象出生的年、月、日,其中年份用四位数字表示,年、月、日之间不用分隔符。顺序码表示同一地址码所标识的区域范围内,对同年、月、日出生的人员编定的顺序号。顺序码的奇数分给男性,偶数分给女性

2、。校验码是根据前面十七位数字码,按照ISO7064:1983.MOD11-2校验码计算出来的检验码。下面举例说明该计算方法。15位的身份证编码首先把出生年扩展为4位,简单的就是增加一个19,但是这对于1900年出生的人不使用(这样的寿星不多了)某男性公民身份号码本体码为34052419800101001,首先按照公式⑴计算:∑(ai×Wi)(mod11)……………………………………(1)公式(1)中:i----表示号码字符从右至左包括校验码在内的位置序号;ai----表示第i位置上的号码字符值;Wi----示第i位置上的加权因子,其数值依据公式Wi=2(n-1)(mod11)

3、计算得出。i181716151413121110987654321ai34052419800101001a1Wi79105842163791058421ai×Wi21360251616294800905002a1根据公式(1)进行计算:∑(ai×Wi)=(21+36+0+25+16+16+2+9+48++0+0+9+0+5+0+0+2)=189189÷11=17+2/11∑(ai×Wi)(mod11)=2然后根据计算的结果,从下面的表中查出相应的校验码,其中X表示计算结果为10:∑(ai×WI)(mod11)012345678910校验码字符值ai10X98765432根据上

4、表,查出计算结果为2的校验码为所以该人员的公民身份号码应该为34052419800101001X。一个校验身份证号码合法的C程序2008年03月25日星期二下午05:05//摘自MyZone,未亲自验证!#include#include#include#includeintIsDigitBuf(char*sBuf,intnLen){inti;if(nLen==0)return1;if(nLen>strlen(sBuf))nLen=strlen(sBuf);for(i=0;i

5、igit(sBuf[i]))return0;return1;}intcheckdate(intiYear,intiMonth,intiDay){if(iYear<0

6、

7、iYear>9999)return-1;switch(iMonth){case1:case3:case5:case7:case8:case10:case12:if(iDay<=0

8、

9、iDay>31){return-3;}break;case4:case6:case9:case11:if(iDay<=0

10、

11、iDay>30){return-3;}break;case2:if((iYear%4==0&&iYear%1

12、00!=0)

13、

14、iYear%400==0){if(iDay<=0

15、

16、iDay>29){return-3;}}else{if(iDay<=0

17、

18、iDay>28){return-3;}}break;default:return-2;}return0;}intCheckStrDate(char*sDate){intiRet;charsYear[5];charsMonth[3];charsDay[3];memset(sYear,0,sizeof(sYear));memset(sMonth,0,sizeof(sMonth));memset(sDay,0,sizeof(sDay));if

19、(strlen(sDate)!=8){return-1;}memcpy(sYear,sDate,4);memcpy(sMonth,sDate+4,2);memcpy(sDay,sDate+6,2);iRet=checkdate(atoi(sYear),atoi(sMonth),atoi(sDay));if(iRet!=0){return-1;}return0;}intmain(intargc,char*argv[]){inti;intiRet;intiWeight[18]={7,9,10,5,8,4,2

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。