zoukankan      html  css  js  c++  java
  • 验证合法身份证

    验证合法身份证

    /*
     * 计算方法
     *      1、将身份证号码前17位数分别乘以不同的系数。系数依次为: 7 9 10 5 8 4 2 1 6 3 7 9 10 5 8 4 2;
     *      2、将这17位数字和系数相乘的结果相加;
     *      3、用加出来和除以11,看余数是多少;
     *      4、余数只可能有0 1 2 3 4 5 6 7 8 9 10这11个数字,其分别对应的最后一位身份证的号码为1 0 X 9 8 7 6 5 4 3 2;
     *      5、通过上面得知如果余数是2,就会在身份证的第18位数字上出现罗马数字的X,如果余数是10,身份证的最后一位号码就是2;
     *
     *  例如:某男性的身份证号码是34052419800101001X。我们要看看这个身份证是不是合法的身份证。
     *  首先:我们计算3*7+4*9+0*10+5*5+...+1*2,前17位的乘积和是189
     *  然后:用189除以11得出的结果是商17余2
     *  最后:通过对应规则就可以知道余数2对应的数字是x。所以,这是一个合格的身份证号码。
     */
    
    - (BOOL)isValidIdentityCard:(NSString *)idCard {
    
      if (idCard.length < 18 || idCard.length > 18) {
        return NO;
      }
    
        // 系数数组
        int factor[] = { 7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2 };
        // 校验码数组
        char code[] = { '1', '0', 'X', '9', '8', '7', '6', '5', '4', '3', '2' };
        
        // 各位与系数相乘求和
        int result = 0;
        for (int i=0; i<17; i++) {
            int temp = [[idCard substringWithRange:NSMakeRange(i, 1)] intValue];
            result += temp * factor[i];
        }
        
        // 求余取对应验证码
        result = code[result % 11];
        
        // 比较验证码
        if (result == [idCard characterAtIndex:17]) {
            return YES;
        } else {
            return NO;
        }
    }
    
    时常一个人发呆,看到宁静的天空。
  • 相关阅读:
    sonar6.7.2启动报错
    linux 查看/修改jdk版本
    idea一款颜值很高的theme
    生成唯一UUID
    连接池异常
    手机网页点击后出现蓝色框
    iScroll4中事件点击一次却触发两次解决方案
    base.js
    javascript与css3动画学习笔记
    javascript对象学习笔记
  • 原文地址:https://www.cnblogs.com/pinweyshg/p/5282342.html
Copyright © 2011-2022 走看看