此代码为js代码,可验证居民身份证的格式是否为正确格式,加入了标准的验证方法。
计算方法
1、将前面的身份证号码17位数分别乘以不同的系数。从第一位到第十七位的系数分别为:7-9-10-5-8-4-2-1-6-3-7-9-10-5-8-4-2。
2、将这17位数字和系数相乘的结果相加。
3、用加出来和除以11,看余数是多少?
4、余数只可能有0-1-2-3-4-5-6-7-8-9-10这11个数字。其分别对应的最后一位身份证的号码为1-0-X -9-8-7-6-5-4-3-2。(即余数0对应1,余数1对应0,余数2对应X...)
5、通过上面得知如果余数是3,就会在身份证的第18位数字上出现的是9。如果对应的数字是2,身份证的最后一位号码就是罗马数字X。
例如:某男性的身份证号码为【53010219200508011X】, 我们看看这个身份证是不是符合计算规则的身份证。
首先我们得出前17位的乘积和【(57)+(39)+(010)+(15)+(08)+(24)+(12)+(91)+(26)+(03)+(07)+(59)+(010)+(85)+(08)+(14)+(1*2)】是189,然后用189除以11得出的结果是189÷11=17余下2,187÷11=17,还剩下2不能被除尽,也就是说其余数是2。最后通过对应规则就可以知道余数2对应的检验码是X。所以,可以判定这是一个正确的身份证号码。
相关资料:https://baike.baidu.com/item/%E5%B1%85%E6%B0%91%E8%BA%AB%E4%BB%BD%E8%AF%81%E5%8F%B7%E7%A0%81/3400358
<!DOCTYPE html>
<html lang="zh">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
<style>
</style>
</head>
<body>
<input type="text" class="input"><span class="hint"></span>
<br>
<input type="submit" value="验证" class="submit">
</body>
<script>
let password = document.querySelector('.input');
let hint = document.querySelector('.hint');
password.oninput = function () {
let regPassword = /^[1-9]\d{5}(18|19|20)\d{2}(0[1-9]|1[0-2])(0[1-9]|1[0-9]|2[0-9]|3[0-1])\d{3}(\d|X|x)$/;
if (regPassword.test(password.value)) {
hint.innerText = '格式正确!';
hint.style.cssText = "color:green;font-size:12px;"
} else {
hint.innerText = '输入有误,请重新输入';
hint.style.cssText = "color:red;font-size:12px;"
}
}
let submit = document.querySelector('.submit');
submit.onclick = function () {
if (password.value === '') {
hint.innerText = '内容不能为空,请重新输入';
hint.style.cssText = "color:red;font-size:12px;"
} else if (password.value.length == 18) {
let sum = (Number(password.value[0]) * 7 + Number(password.value[1]) * 9 + Number(password.value[2]) * 10 + Number(password.value[3]) * 5 + Number(password.value[4]) * 8 + Number(password.value[5]) * 4 + Number(password.value[6]) * 2 + Number(password.value[7]) * 1 + Number(password.value[8]) * 6 + Number(password.value[9]) * 3 + Number(password.value[10]) * 7 + Number(password.value[11]) * 9 + Number(password.value[12]) * 10 + Number(password.value[13]) * 5 + Number(password.value[14]) * 8 + Number(password.value[15]) * 4 + Number(password.value[16]) * 2) % 11;
console.log(sum);
let newresult = 0;
switch (sum) {
case 0: newresult = 1;
break;
case 1: newresult = 0;
break;
case 2: newresult = 'X';
break;
case 3: newresult = 9;
break;
case 4: newresult = 8;
break;
case 5: newresult = 7;
break;
case 6: newresult = 6;
break;
case 7: newresult = 5;
break;
case 8: newresult = 4;
break;
case 9: newresult = 3;
break;
case 10: newresult = 2;
break;
}
if (newresult == (password.value[17]).toUpperCase()) {//最后一位可能是小写,需要转为大写
alert('身份证格式验证"正确"')
} else {
alert('身份证格式验证"错误"')
}
// alert(Object.prototype.toString.call(password.value))//检测输出的字符为字符串类型,伪数组
//利用下标验证
}
}
//计算方法
// 1、将前面的身份证号码17位数分别乘以不同的系数。从第一位到第十七位的系数分别为:7-9-10-5-8-4-2-1-6-3-7-9-10-5-8-4-2。
// 2、将这17位数字和系数相乘的结果相加。
// 3、用加出来和除以11,看余数是多少?
// 4、余数只可能有0-1-2-3-4-5-6-7-8-9-10这11个数字。其分别对应的最后一位身份证的号码为1-0-X -9-8-7-6-5-4-3-2。(即余数0对应1,余数1对应0,余数2对应X...)
// 5、通过上面得知如果余数是3,就会在身份证的第18位数字上出现的是9。如果对应的数字是2,身份证的最后一位号码就是罗马数字X。
// 例如:某男性的身份证号码为【53010219200508011X】, 我们看看这个身份证是不是符合计算规则的身份证。
// 首先我们得出前17位的乘积和【(5*7)+(3*9)+(0*10)+(1*5)+(0*8)+(2*4)+(1*2)+(9*1)+(2*6)+(0*3)+(0*7)+(5*9)+(0*10)+(8*5)+(0*8)+(1*4)+(1*2)】是189,然后用189除以11得出的结果是189÷11=17余下2,187÷11=17,还剩下2不能被除尽,也就是说其余数是2。最后通过对应规则就可以知道余数2对应的检验码是X。所以,可以判定这是一个正确的身份证号码。
</script>
</html>