最近需要对身份证合法性进行验证,找了一个不错的JS验证方法。
不是单纯的验证身份证位数哦,可以有效的验证身份证的有效性以及合法性
方法源码:
function cardindex(){ var obj = $("input[name='card']"); var idCard = obj.val(); //15位和18位身份证号码的正则表达式 var 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(regIdCard.test(idCard)){ if(idCard.length==18){ //将前17位加权因子保存在数组里 var idCardWi=new Array( 7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2 ); //这是除以11后,可能产生的11位余数、验证码,也保存成数组 var idCardY=new Array( 1, 0, 10, 9, 8, 7, 6, 5, 4, 3, 2 ); //用来保存前17位各自乖以加权因子后的总和 var idCardWiSum=0; for(var i=0;i<17;i++){ idCardWiSum+=idCard.substring(i,i+1)*idCardWi[i]; } var idCardMod=idCardWiSum%11;//计算出校验码所在数组的位置 var idCardLast=idCard.substring(17);//得到最后一位身份证号码 //如果等于2,则说明校验码是10,身份证号码最后一位应该是X if(idCardMod==2){ if(idCardLast=="X"||idCardLast=="x"){ return true; //alert("恭喜通过验证啦!"); }else{ layer.tips('身份证号有误,或不存在!', obj ,{ tips: [3, 'red'], time: 2000 }); return false; //alert("身份证号码错误!"); } }else{ //用计算出的验证码与最后一位身份证号码匹配, if(idCardLast==idCardY[idCardMod]){ return true; // 恭喜通过验证 }else{ layer.tips('身份证号有误,或不存在!', obj ,{ tips: [3, 'red'], time: 2000 }); return false; //身份证号码错误; } } } }else{ layer.tips('身份证号有误,或不存在!', obj ,{ tips: [3, 'red'], time: 2000 }); return false; //alert("身份证格式不正确!"); } }