身份证号的检测

来源:互联网 发布:阿里云网址是多少 编辑:程序博客网 时间:2024/06/07 05:58

ddddddyyyymmddxxsp共18位

公民身份号码是特征组合码,由十七位数字本体码和一位校验码组成。排列顺序从左至右依次为:六位数字地址码,八位数字出生日期码,三位数字顺序码和一位数字校验码。

 2.地址码 
  表示编码对象常住户口所在县(市、旗、区)的行政区划代码,按GB/T2260的规定执行。 
  3.出生日期码 
  表示编码对象出生的年、月、日,按GB/T7408的规定执行,年、月、日代码之间不用分隔符。 
  4.顺序码 
  表示在同一地址码所标识的区域范围内,对同年、同月、同日出生的人编定的顺序号,顺序码的奇数分配给男性,偶数分配给女性。 
  5.校验码
  根据前面十七位数字码,按照ISO 7064:1983.MOD 11-2校验码计算出来的检验码

身份证号的检测算法:

一,检测地区码是否合法,二,检测出生日期是否正确,三,检测校对码是否正确(校对码的检测,前17位加权取和后取模)。

 int weight[17] = {7,9,10,5,8,4,2,1,6,3,7,9,10,5,8,4,2};//第一位到第十七位身份证权值表
int checkCode[11] = {1,0,10,9,8,7,6,5,4,3,2};// 模以11得到的结果下标对应其检验码表

//检查出生日期是否正确~bool detectBirthDate(int id[]){int year,month,day;year  = id[6]*1000 + id[7]*100 +  id[8]*10 + id[9]*1;month = id[10] * 10 + id[11];day   = id[12] * 10 + id[13];bool  isLegal = true;int dayNum[12] = {31,29,31,30,31,30,31,31,30,31,30,31};if (year < 1900 || year > 2014 || month > 13 || day > dayNum[month-1]){isLegal = false;cout<<"year or month or day error"<<endl;}if(!((year % 4 == 0 && year % 100 != 0 ) || year % 400 == 0) && day > 28 && month == 2){isLegal = false;cout<<"day error"<<endl;}return isLegal;}//检查身份证号是否正确bool detectID(char * inputID){int len = strlen(inputID);if (len != 18){return false;}int id[18];for (int i = 0; i < len; i++){if (inputID[i] == 'X' || inputID[i] == 'x')//末位罗马数字X表示10id[i] = 10;elseid[i] = inputID[i] - '0';}int weight[17] = {7,9,10,5,8,4,2,1,6,3,7,9,10,5,8,4,2};//第一位到第十七位身份证权值int checkCode[11] = {1,0,10,9,8,7,6,5,4,3,2};// 模以11得到的结果下标对应其检验码//这里应该先去较对前6位的地区码是否合法的 但是整理行政区划分太麻烦了 囧bool isLegal = detectBirthDate(id);    if (isLegal)    {int sum = 0;for (int i = 0; i < 17;i++){sum += id[i] * weight[i];}int mod = sum % 11;if (id[17] != checkCode[mod]){isLegal = false;cout<<"code error"<<endl;}    }return isLegal;}



0 0
原创粉丝点击