欢迎来到天天文库
浏览记录
ID:19416229
大小:29.50 KB
页数:8页
时间:2018-10-02
《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;i5、igit(sBuf[i]))return0;return1;}intcheckdate(intiYear,intiMonth,intiDay){if(iYear<06、7、iYear>9999)return-1;switch(iMonth){case1:case3:case5:case7:case8:case10:case12:if(iDay<=08、9、iDay>31){return-3;}break;case4:case6:case9:case11:if(iDay<=010、11、iDay>30){return-3;}break;case2:if((iYear%4==0&&iYear%112、00!=0)13、14、iYear%400==0){if(iDay<=015、16、iDay>29){return-3;}}else{if(iDay<=017、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));if19、(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
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
此文档下载收益归作者所有