最近需要对身份证合法性进行验证,找了一个不错的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("身份证格式不正确!");
}
}转载请注明来源地址:小川编程 » https://www.youhutong.com/index.php/article/index/107.html
1、本站发布的内容仅限用于学习和研究目的.请勿用于商业或非法用途,下载后请24小时内删除。
2、本站所有内容均不能保证其完整性,不能接受请勿购买或下载,如需完整程序,请去其官方购买正版使用
3、本站联系方式Email:admin@youhutong.com ,收到邮件会第一时间处理。
4、如侵犯到任何版权问题,请立即告知本站(立即在线告知),本站将及时删除并致以最深的歉意



