检验身份证的正确性(C语言版本)

/* check id_card 
* write by sndnvaps<sndnvaps@gmail.com> * ai -> a1 , a2, a3, a4, a5, a6... a17 (a18 是校验码) 身份证前17位对应(ai) * wi -> 7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2 (17位) * * int res = 0; * for (i = 1; i < 17; i++) { * res += (a[i] * w[i]) * } * int y = res % 11; * * * y 与 a18的对应关系 * * y { 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10} * a18 { 1, 0, 'X', 9, 8, 7, 6, 5, 4, 3, 2 } -> vefiry[18] = { 1, 0, 'X', 9, 8, 7, 6, 5, 4, ,3, 2};
*/ #include <stdio.h> #include <stdlib.h> #include <string.h> int wi[17] = { 7, 9, 10, 5, 8 , 4, 2, 1, 6, 3, 7, 9 , 10, 5, 8, 4, 2}; int a18[11] = { 1, 0, 'X', 9, 8, 7, 6, 5, 4, 3, 2}; int char2int(char n) { return (n - 48); } int check_id(char id[17] ) {//return y int res = 0; int y; int i; for (i = 0; i < 17; i++) { res += (char2int(id[i]) * wi[i]); } y = res % 11; return y; } int verify_id_t(int verify_id, int id_v) { //verify_id = y; id_v = a18 int i; int temp; //store the i ; for (i = 0; i < 10; i++) { if (i == verify_id) { temp = a18[i]; printf("a18[%d] = %d\n", i, temp); break; } } if (temp == id_v) return 1; // get it , 验证合格 return 0; } void usage() { printf("check_id_card id_card_num \n"); } int main(int argc, char *argv[]) { if (argc < 2) { usage(); } char id_string[18]; int id_18; int i; int y; if (strlen(argv[1]) > 18) { printf("id_card_num must be 18 bits\n");
return 0; } strncpy(id_string, argv[
1], 18); id_18 = char2int(id_string[17]); id_string[17] = '\0'; printf("id_18 = %d\n", id_18); y = check_id(id_string); if(verify_id_t(y, id_18) == 1) { printf("verify success\n"); } else { printf("verify failed\n"); } return 0; }

 

转载于:https://www.cnblogs.com/sn-dnv-aps/p/3683794.html

C语言中,由于其本身不是一种高级安全编程语言,处理身份证号码验证通常会涉及到字符串操作、正则表达式或者一些预定义的身份验证库(如果有的话)。以下是一个基本的步骤描述: 1. **数据结构**:首先,需要定义一个字符串数组存储身份证号码的各个部分,比如前六位、出生日期等。 2. **校验规则**:中国身份证号码由18位数字组成,有一定的校验规则,如奇偶校验码、地区代码检查等。你需要了解这些规则以便编写相应的函数。 3. **正则表达式**:你可以使用C标准库中的`regcomp`和`regexec`函数配合正则表达式来验证特定的部分,比如第7-14位是否符合日期格式,第15-17位是否是顺序码等。 4. **校验码计算**:根据身份证号码最后一位来检查校验码是否正确,这通常涉及数学运算和对应的校验码公式。 ```c #include <stdio.h> #include <regex.h> int is_valid_idcard(char *id) { // 正则表达式示例 regex_t regex; int rc = regcomp(&regex, "^\\d{6}(19|20)[0-9]{2}(0[1-9]|1[0-2])(0[1-9]|[12][0-9]|3[01])\\d{3}$", REG_EXTENDED); if (rc != 0) { printf("Invalid regular expression\n"); return 0; // 非法格式 } if (regexec(&regex, id, 0, NULL, 0) == 0) { // 如果匹配,则继续计算校验码 // ... (其他校验步骤) } else { regfree(&regex); return 1; // 格式正确但校验失败 } } int main() { char id[] = "123456789012345678"; if (is_valid_idcard(id)) { printf("Valid ID card.\n"); } else { printf("Invalid ID card.\n"); } regfree(&regex); return 0; } ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值