身份证合法性校验规则

本文介绍了身份证号码的构成,包括行政区域编码、出生日期、顺序号和校验码,并详细阐述了身份证的格式校验和合法性校验过程,包括出生年月日的合理性检查以及ISO7064:1983.MOD11-2校验码算法的运用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

  • 身份证构成说明:

 

身份证号构成(从左到右):

第1-6位数是行政区域编码

第7到第14位是出生日期

第15-17位是同一天出生的顺序号(男的用奇数数,女的用偶数)

第18位是校验码,根据ISO7064:1983.MOD11-2校验码算法可以验证该身份证号是否合法身份证号。

  • 身份证格式校验:

1、取第7到10位的字符,校验出生年份:是否在 1900年到2022年之间的;

2、取第11到12位的字符,校验出生月份:是否在1-12;

3、取第13到14位校验日期:是否在1-31;

以上三步都校验通过,说明用户的身份证通过格式校验;

  • 身份证合法性校验&
在Qt中实现身份证合法性校验通常涉及到中国居民身份证号码的验证规则,这些规则包括数字位数、校验码计算等。由于这种校验涉及到正则表达式和特定算法,我们可以利用Qt的QRegExp或自定义函数来完成。 以下是一个简单的步骤概述: 1. **包含必要的库**:首先,在Qt项目中引入所需的正则表达式库(如`<regex>`)。 2. **定义身份证号的正则表达式**:创建一个正则表达式来匹配中国大陆的18位或15位身份证号。例如: ```cpp QRegExp idCardPattern("(\\d{6})(1[89]|20)?(\\d{4})(0[1-9]|1[0-2])(0[1-9]|[12][0-9]|3[01])([0-9Xx]{1})"); ``` 3. **校验方法**:编写一个函数来检查输入的字符串是否匹配该模式,并执行校验码的计算。对于18位身份证,计算第17位校验码;对于15位身份证,不计算最后一位。 ```cpp bool isValidIDCard(QString id) { if (!idCardPattern.exactMatch(id)) return false; // 初步校验长度 // 根据身份证的结构计算校验码,这里仅示例18位身份证的计算 int sum = 0; for (int i = 0; i < 17; ++i) { sum += (i % 2 == 0) ? id[i] - '0' * 2 : id[i] - '0'; } int checkCode = (sum % 11 > 1) ? 11 - sum % 11 : sum % 11; return checkCode == id[id.size() - 1].toInt(); // 检查最终校验码是否一致 } ``` 4. **调用校验函数**:在用户输入身份证号码后,使用`isValidIDCard`函数验证其有效性。 记得这只是一个基础的示例,实际应用可能需要处理更复杂的边界情况,比如出生日期的有效性等。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值