身份证最后一位算法 JavaScript实现

1.将下面代码复制到记事本中,保存文件名为 *.html

2.使用浏览器打开就可以使用了。


<html>
<head>
<title>JavaScript</title>
</head>
<body>
请输入身份证号码:<br>
<input type="text" name="card"><br>
<input type="button" value="验证18位身份证" οnclick="submit1();">
<input type="button" value="17位转18位身份证" οnclick="submit2();">
<input type="button" value="预留按钮" οnclick="submit3();">
<br><br>身份证号验证脚本 作者:xzlAwin<br>
<script type="text/javascript">
function submit3()
{
alert('预留的按钮未实现功能!');
}
function submit1()
{
var card = document.getElementsByName('card')[0].value;
//alert(card);
//coefficient 加权系数
var coefficient=[7,9,10,5,8,4,2,1,6,3,7,9,10,5,8,4,2];
//validate 验证码
var validate = [1,0,'X',9,8,7,6,5,4,3,2];
card = card.split('');
if(card.length == 18)
{
var sum = 0;
for(var i=0;i<card.length-1;i++)
{
sum += parseInt(card[i])*parseInt(coefficient[i]);
//alert(parseInt(coefficient[i]));
}
if(card[17] == validate[sum%11])
{
alert('身份证号码正确!');
}else
{
alert('身份证号码错误!');
}
//alert(validate[sum%11]);
}else
{
alert('输入位数错误:要求输入18位数字,您输入了'+card.length+'位数!');
}
}
function submit2()
{
var card = document.getElementsByName('card')[0].value;
//alert(card);
//coefficient 加权系数
var coefficient=[7,9,10,5,8,4,2,1,6,3,7,9,10,5,8,4,2];
//validate 验证码
var validate = [1,0,'X',9,8,7,6,5,4,3,2];
card = card.split('');
if(card.length == 17)
{
var sum = 0;
for(var i=0;i<card.length;i++)
{
sum += parseInt(card[i])*parseInt(coefficient[i]);
//alert(parseInt(coefficient[i]));
}
alert('最后一位验证码是:'+validate[sum%11]+'\n'
+'完整的身份证号是:'+card.join('')+validate[sum%11]);
}else
{
alert('输入位数错误:要求输入17位数字,您输入了'+card.length+'位数!');
}
}
</script>
</body>
</html>

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值