• 身份证号码验证正则表达式


    方案0:

    https://git.oschina.net/osworks/G4Studio/blob/master/project/webapp/resource/commonjs/g4studio.js?oid=cc7954f9d17a97a02e248151ab4193c39f2f460b

    function isIdCardNo(num) {
        if (Ext.isEmpty(num))
            return false;
        num = num.toUpperCase();
        // 身份证号码为15位或者18位,15位时全为数字,18位前17位为数字,最后一位是校验位,可能为数字或字符X。
    
    
        if (!(/(^d{15}$)|(^d{17}([0-9]|X)$)/.test(num))) {
            Ext.MessageBox.alert('提示',
                    '输入的身份证号长度不对,或者号码不符合规定!
    15位号码应全为数字,18位号码末位可以为数字或X。');
            return false;
        }
        // 校验位按照ISO 7064:1983.MOD 11-2的规定生成,X可以认为是数字10。
    
    
        // 下面分别分析出生日期和校验位
    
    
        var len, re;
        len = num.length;
        if (len == 15) {
            re = new RegExp(/^(d{6})(d{2})(d{2})(d{2})(d{3})$/);
            var arrSplit = num.match(re);
            // 检查生日日期是否正确
    
    
            var dtmBirth = new Date('19' + arrSplit[2] + '/' + arrSplit[3] + '/'
                    + arrSplit[4]);
            var bGoodDay;
            bGoodDay = (dtmBirth.getYear() == Number(arrSplit[2]))
                    && ((dtmBirth.getMonth() + 1) == Number(arrSplit[3]))
                    && (dtmBirth.getDate() == Number(arrSplit[4]));
            if (!bGoodDay) {
                Ext.MessageBox.alert('提示', '输入的身份证号里出生日期不对!');
                return false;
            } else {
                // 将15位身份证转成18位
    
    
                // 校验位按照ISO 7064:1983.MOD 11-2的规定生成,X可以认为是数字10。
    
    
                var arrInt = new Array(7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5,
                        8, 4, 2);
                var arrCh = new Array('1', '0', 'X', '9', '8', '7', '6', '5', '4',
                        '3', '2');
                var nTemp = 0, i;
                num = num.substr(0, 6) + '19' + num.substr(6, num.length - 6);
                for (i = 0; i < 17; i++) {
                    nTemp += num.substr(i, 1) * arrInt[i];
                }
                num += arrCh[nTemp % 11];
                return num;
            }
        }
        if (len == 18) {
            re = new RegExp(/^(d{6})(d{4})(d{2})(d{2})(d{3})([0-9]|X)$/);
            var arrSplit = num.match(re);
            // 检查生日日期是否正确
    
    
            var dtmBirth = new Date(arrSplit[2] + "/" + arrSplit[3] + "/"
                    + arrSplit[4]);
            var bGoodDay;
            bGoodDay = (dtmBirth.getFullYear() == Number(arrSplit[2]))
                    && ((dtmBirth.getMonth() + 1) == Number(arrSplit[3]))
                    && (dtmBirth.getDate() == Number(arrSplit[4]));
            if (!bGoodDay) {
                // alert(dtmBirth.getYear());
    
    
                // alert(arrSplit[2]);
    
    
                Ext.MessageBox.alert('提示', '输入的身份证号里出生日期不对!');
                return false;
            } else {
                // 检验18位身份证的校验码是否正确。
    
    
                // 校验位按照ISO 7064:1983.MOD 11-2的规定生成,X可以认为是数字10。
    
    
                var valnum;
                var arrInt = new Array(7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5,
                        8, 4, 2);
                var arrCh = new Array('1', '0', 'X', '9', '8', '7', '6', '5', '4',
                        '3', '2');
                var nTemp = 0, i;
                for (i = 0; i < 17; i++) {
                    nTemp += num.substr(i, 1) * arrInt[i];
                }
                valnum = arrCh[nTemp % 11];
                if (valnum != num.substr(17, 1)) {
                    Ext.MessageBox.alert('提示', '18位身份证的校验码不正确!应该为:' + valnum);
                    return false;
                }
                return num;
            }
        }
        return false;
    }

    方案1:

    http://www.cnblogs.com/inhesoft/archive/2007/12/01/979383.html#3370247

    /^(d{15}$|^d{18}$|^d{17}(d|X|x))$/

    方案2:

    http://zhidao.baidu.com/question/473117318.html?fr=iks&word=%C9%ED%B7%DD%D6%A4%BA%C5+%D5%FD%D4%F2&ie=gbk

    15位数身份证验证正则表达式:
    isIDCard1=/^[1-9]d{7}((0d)|(1[0-2]))(([0|1|2]d)|3[0-1])d{3}$/; 
    18位数身份证验证正则表达式 :
    isIDCard2=/^[1-9]d{5}[1-9]d{3}((0d)|(1[0-2]))(([0|1|2]d)|3[0-1])d{3}([0-9]|X)$/;

    方案2最佳,方案0用户体验最好。

  • 相关阅读:
    AGC015E Mr.Aoki Incubator
    luogu P3520 [POI2011]SMI-Garbage
    442.Find All Duplicates in an Array
    SICP_2.61-2.62
    sicp_2.59-2.60
    SICP_2.58
    SICP_2.56-2.57
    SICP_2.53-2.55
    SICP_2.52-2.53
    SICP_2.50-2.51
  • 原文地址:https://www.cnblogs.com/rgqancy/p/5485786.html
Copyright © 2020-2023  润新知