JS011. 身份证号码校验(仅34行)
2024-08-31 06:03:35
身份证格式
六位数字地址码 + 八位数字出生日期码 + 三位数字顺序码 + 一位数字校验码
checkIdCard.js
checkIdCard: function (idCard){
//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){
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(vari=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;
}else{
return false;
}
}else{
//用计算出的验证码与最后一位身份证号码匹配,如果一致,说明通过,否则是无效的身份证号码
if(idCardLast==idCardY[idCardMod]){
return true;
}else{
return false;
}
}
}
}else{
return false;
}
}
看到网上有很多朋友用正则和字符串判断码了过百行代码,实在不适合只在单个文件中应用的场景,只有这段代码简练且精确,适合不封装直接使用。
相关资源:JS完美校验身份证号有效性函数(亲测)
- END -
最新文章
- scikit-learn一般实例之一:保序回归(Isotonic Regression)
- django在pyhton2.7 和 python3.* 之间代码和睦相处的方法
- 4.html5中超链接
- C#&;java重学笔记(泛型)
- Java8新特性 1——利用流和Lambda表达式操作集合
- JAXB - Annotations, The Annotation XmlElement
- jQuery如何阻止子元素继承父元素事件?
- Math对象
- css多行文本垂直居中问题研究
- 关于C#静态构造函数的几点说明
- Java Web实现IOC控制反转之依赖注入
- Android程序崩溃异常处理框架
- 在 root 下执行 Oracle 程序时找不到 libclntsh.so.11.1 错误的解决办法。
- C#基础加强(8)之委托和事件
- 窥看 SpringBoot 的原理与使用
- pip报错解决:EnvironmentError: mysql_config not found
- Scala学习(三)----数组相关操作
- python socket编程和黏包问题
- SpringBoot :docker
- BZOJ5074 小B的数字