zoukankan      html  css  js  c++  java
  • 身份证号

    Validation.add('validate-identify', '无效的身份证号', function(v) {
    
    
            var regIdCard=/^(^[1-9]d{7}((0d)|(1[0-2]))(([0|1|2]d)|3[0-1])d{3}$)|(^[1-9]d{5}[1-9]d{3}((0d)|(1[0-2]))(([0|1|2]d)|3[0-1])((d{4})|d{3}[Xx])$)$/;
    
            var flag = false;
            if(regIdCard.test(v)){
                if(v.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+=v.substring(i,i+1)*idCardWi[i];
                    }
    
                    var idCardMod=idCardWiSum%11;//计算出校验码所在数组的位置
                    var idCardLast=v.substring(17);//得到最后一位身份证号码
    
                    //如果等于2,则说明校验码是10,身份证号码最后一位应该是X
                    if(idCardMod==2){
                        if(idCardLast=="X"||idCardLast=="x"){
                            flag = true;
                        }
                    }else{
                        //用计算出的验证码与最后一位身份证号码匹配,如果一致,说明通过,否则是无效的身份证号码
                        if(idCardLast==idCardY[idCardMod]){
    
                            flag = true;
                        }
                    }
                }
            }
    
            return flag;
        });
    

      

    作者:冯亮
             
    能力有限,水平一般。如有错误,欢迎指正
  • 相关阅读:
    快速排序
    冒泡排序
    桶排序
    Writer及其子类
    Reader及其子类
    OutputStream及其子类
    InputStream及其子类
    基础IO类和相关方法
    File类
    枚举
  • 原文地址:https://www.cnblogs.com/fengliang/p/7131510.html
Copyright © 2011-2022 走看看