javascript实现验证身份证号的有效性并提示

javascript实现验证身份证号的有效性并提示

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
function nunber(allowancePersonValue){
 if(allowancePersonValue=="身份证号"){
 $("#span_username").show();
 $("#span_username").html("身份证号不能为空");
 return false;
 }
 //校验长度,类型
 else if(isCardNo(allowancePersonValue) === false)
 {
$("#span_username").show();
 $("#span_username").html("您输入的身份证号码不正确,请重新输入");
 return false;
 }
 //检查省份
 else if(checkProvince(allowancePersonValue) === false)
 {
 $("#span_username").show();
 $("#span_username").html("您输入的身份证号码不正确,请重新输入");
 return false;
 }
 //校验生日
 else if(checkBirthday(allowancePersonValue) === false)
 {
 $("#span_username").show();
 $("#span_username").html("您输入的身份证号码生日不正确,请重新输入");
 return false;
 }
 //检验位的检测
 else if(checkParity(allowancePersonValue) === false)
 {
 $("#span_username").show();
 $("#span_username").html("您的身份证校验位不正确,请重新输入");
 return false;
 }else{
 $("#span_username").hide();
 return true;
 }
  
}
  
//身份证省的编码
var vcity={ 11:"北京",12:"天津",13:"河北",14:"山西",15:"内蒙古",
    21:"辽宁",22:"吉林",23:"黑龙江",31:"上海",32:"江苏",
    33:"浙江",34:"安徽",35:"福建",36:"江西",37:"山东",41:"河南",
    42:"湖北",43:"湖南",44:"广东",45:"广西",46:"海南",50:"重庆",
    51:"四川",52:"贵州",53:"云南",54:"西藏",61:"陕西",62:"甘肃",
    63:"青海",64:"宁夏",65:"新疆",71:"台湾",81:"香港",82:"澳门",91:"国外"
    };
  
//检查号码是否符合规范,包括长度,类型
function isCardNo(card){
 //身份证号码为15位或者18位,15位时全为数字,18位前17位为数字,最后一位是校验位,可能为数字或字符X
 var reg = /(^\d{15}$)|(^\d{17}(\d|X)$)/;
 if(reg.test(card) === false){
 //alert("demo");
 return false;
 }
 return true;
}
  
//取身份证前两位,校验省份
function checkProvince(card){
 var province = card.substr(0,2);
 if(vcity[province] == undefined){
 return false;
 }
 return true;
}
  
//检查生日是否正确
function checkBirthday(card){
 var len = card.length;
 //身份证15位时,次序为省(3位)市(3位)年(2位)月(2位)日(2位)校验位(3位),皆为数字
 if(len == '15'){
   var re_fifteen = /^(\d{6})(\d{2})(\d{2})(\d{2})(\d{3})$/;
   var arr_data = card.match(re_fifteen);
   var year = arr_data[2];
   var month = arr_data[3];var day = arr_data[4];var birthday =newDate('19'+year+'/'+month+'/'+day);return verifyBirthday('19'+year,month,day,birthday);}//身份证18位时,次序为省(3位)市(3位)年(4位)月(2位)日(2位)校验位(4位),校验位末尾可能为X if(len =='18'){var re_eighteen =/^(\d{6})(\d{4})(\d{2})(\d{2})(\d{3})([0-9]|X)$/;var arr_data = card.match(re_eighteen);var year = arr_data[2];var month = arr_data[3];var day = arr_data[4];var birthday =newDate(year+'/'+month+'/'+day);return verifyBirthday(year,month,day,birthday);}returnfalse;}//校验日期 function verifyBirthday(year,month,day,birthday){var now =newDate();var now_year = now.getFullYear();//年月日是否合理 if(birthday.getFullYear()== year &&(birthday.getMonth()+1)== month && birthday.getDate()== day){//判断年份的范围(3岁到100岁之间) var time = now_year - year;if(time >=3&& time <=100){returntrue;}returnfalse;}returnfalse;}//校验位的检测 function checkParity(card){//15位转18位
 card = changeFivteenToEighteen(card);var len = card.length;if(len =='18'){var arrInt =newArray(7,9,10,5,8,4,2,1,6,3,7,9,10,5,8,4,2);var arrCh =newArray('1','0','X','9','8','7','6','5','4','3','2');var cardTemp =0, i, valnum;for(i =0; i <17; i ++){
     cardTemp += card.substr(i,1)* arrInt[i];}
   valnum = arrCh[cardTemp %11];if(valnum == card.substr(17,1)){returntrue;}returnfalse;}returnfalse;}//15位转18位身份证号 function changeFivteenToEighteen(card){if(card.length =='15'){var arrInt =newArray(7,9,10,5,8,4,2,1,6,3,7,9,10,5,8,4,2);var arrCh =newArray('1','0','X','9','8','7','6','5','4','3','2');var cardTemp =0, i; 
   card = card.substr(0,6)+'19'+ card.substr(6, card.length -6);for(i =0; i <17; i ++){
     cardTemp += card.substr(i,1)* arrInt[i];}
   card += arrCh[cardTemp %11];return card;}return card;}

使用方法:

1
2
<input type="text" class="reg_txt" value="身份证号" titles="请输入您的身份证号!" name="userid" id="username" maxlength="40" onfocus="if(this.value=='身份证号'){this.value='';}" onblur="if(this.value==''){this.value='身份证号';}nunber(this.value);" style="border: 1px solid red;"><br>
<span class="c_red" id="span_username"></span>

效果为输入身份证号,焦掉移开后自动验证,并返回信息!

以上所述就是本文的全部内容了,希望大家能够喜欢。

posted @   susanws  阅读(422)  评论(0编辑  收藏  举报
编辑推荐:
· 如何打造一个高并发系统?
· .NET Core GC压缩(compact_phase)底层原理浅谈
· 现代计算机视觉入门之:什么是图片特征编码
· .NET 9 new features-C#13新的锁类型和语义
· Linux系统下SQL Server数据库镜像配置全流程详解
阅读排行:
· Sdcb Chats 技术博客:数据库 ID 选型的曲折之路 - 从 Guid 到自增 ID,再到
· Winform-耗时操作导致界面渲染滞后
· Phi小模型开发教程:C#使用本地模型Phi视觉模型分析图像,实现图片分类、搜索等功能
· 语音处理 开源项目 EchoSharp
· drools 规则引擎和 solon-flow 哪个好?solon-flow 简明教程
点击右上角即可分享
微信分享提示