JS校验身份证号码是否存在及正确性,不仅仅是校验格式是否正确

本文介绍了一种用于验证中国居民身份证号码有效性的算法。通过详细解释校验码计算过程及正则表达式验证方式,确保身份证号码格式正确且校验码匹配。

function regCardNo() { 
        var regBox = {
                regWord : /^([\u4e00-\u9fa5]{1,6})$/,//六个汉字以内
                regIdCard : /^(^[1-9]\d{7}((0\d)|(1[0-2]))(([0|1|2]\d)|3[0-1])\d{3}$)|(^[1-9]\d{5}[1-9]\d{3}((0\d)|(1[0-2]))(([0|1|2]\d)|3[0-1])((\d{4})|\d{3}[Xx])$)$/
                 //如果通过该验证,说明身份证格式正确,但准确性还需计算
                  
            };
           if(regBox.regIdCard.test($("input[name='idNumber']").val())){
              if($("input[name='idNumber']").val().length==18){
                       var idCardWi=new Array( 7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2 ); //将前17位加权因子保存在数组里
                     var idCardY=new Array( 1, 0, 10, 9, 8, 7, 6, 5, 4, 3, 2 ); //这是除以11后,可能产生的11位余数、验证码,也保存成数组
                     var idCardWiSum=0; //用来保存前17位各自乖以加权因子后的总和
                     for(var i=0;i<17;i++){
                        idCardWiSum+=$("input[name='idNumber']").val().substring(i,i+1)*idCardWi[i];
                     }
                     var idCardMod=idCardWiSum%11;//计算出校验码所在数组的位置
                     var idCardLast=$("input[name='idNumber']").val().substring(17);//得到最后一位身份证号码
                     //如果等于2,则说明校验码是10,身份证号码最后一位应该是X
                     if(idCardMod==2){
                      if(idCardLast!="X" && idCardLast!="x"){
                          alert("身份证号码错误!");
                          return false;
                      }
                     }else{
                      //用计算出的验证码与最后一位身份证号码匹配,如果一致,说明通过,否则是无效的身份证号码
                      if(idCardLast!=idCardY[idCardMod]){
                          alert("身份证号码错误!");
                          return false;
                      }
                   }
                } 
               }else if(!regBox.regIdCard.test($("input[name='idNumber']").val())){
                          alert("身份证格式不正确!");
                          return false;
               }else{
                          return true;
               }
           $("#submit").attr('disabled','disabled').css('background-color','#bbb')
     
    }  

转载于:https://my.oschina.net/dyl226/blog/1505651

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值