身份证号的检测
来源:互联网 发布:阿里云网址是多少 编辑:程序博客网 时间: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
- 身份证号的检测
- JS 姓名、身份证号检测
- 身份证号检测是否正确(实战)
- “身份证号”的数字分析
- 身份证号的较验
- 录入身份证号的宏
- 身份证号校验的 js
- 身份证号的验证
- 推荐人身份证号的验证
- 身份证号的js验证
- 验证身份证号的合法性
- 身份证号
- 身份证号
- 身份证号第18位(效验码)计算方法 用于检测身份证号是否正确
- 身份证号的校检代码
- 身份证号是如何编码的
- 身份证号的组成和校验
- 关于验证身份证号的方法!
- 全排列算法:不含重复元素,包含重复元素,字母序排列
- 新生排位赛第四场 dp
- xml(3)--dom4j实现crud操作
- HDU1325并查集判断是否为一棵树
- Socket:读写处理及连接断开的检测 http://hongdow.com/page/2
- 身份证号的检测
- C链表之创建简单静态链表
- Http协议参数传递中编码问题(Get/Post 方式)
- Android双击以及多击事件
- 3-09. 队列中的元素排序(20)
- 2014 Multi-University Training Contest 1--by FZU 解题报告
- 电流源电路
- 兼容性好的CSS字体投影
- udp套接字使用信号驱动式I/O