基于javascript简单实现对身份证校验


Posted in Javascript onJanuary 25, 2021

本文实例介绍了javascript简单实现对身份证的校验的关键性代码,分享给大家供大家参考,具体内容如下

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:"国外" 
}; 

checkCard = function(card) 
{ 

//是否为空 
if(card === '') 
{ 

return "请输入身份证号,身份证号不能为空"; 
} 
//校验长度,类型 
if(isCardNo(card) === false) 
{ 

return "您输入的身份证号码不正确,请重新输入"; 
} 
//检查省份 
if(checkProvince(card) === false) 
{ 
return "您输入的身份证号码不正确,请重新输入"; 
} 
//校验生日 
if(checkBirthday(card) === false) 
{ 
return "您输入的身份证号码生日不正确,请重新输入"; 
} 
//检验位的检测 
if(checkParity(card) === false) 
{ 
return "您的身份证校验位不正确,请重新输入"; 
} 

return "ok"; 
}; 


//检查号码是否符合规范,包括长度,类型 
isCardNo = function(card) 
{ 
//身份证号码为15位或者18位,15位时全为数字,18位前17位为数字,最后一位是校验位,可能为数字或字符X 
var reg = /(^\d{15}$)|(^\d{17}(\d|X)$)/; 
if(reg.test(card) === false) 
{ 
return false; 
} 

return true; 
}; 

//取身份证前两位,校验省份 
checkProvince = function(card) 
{ 
var province = card.substr(0,2); 
if(vcity[province] == undefined) 
{ 
return false; 
} 
return true; 
}; 

//检查生日是否正确 
checkBirthday = function(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 = new Date('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 = new Date(year+'/'+month+'/'+day); 
return verifyBirthday(year,month,day,birthday); 
} 
return false; 
}; 

//校验日期 
verifyBirthday = function(year,month,day,birthday) 
{ 
var now = new Date(); 
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) 
{ 
return true; 
} 
return false; 
} 
return false; 
}; 

//校验位的检测 
checkParity = function(card) 
{ 
//15位转18位 
card = changeFivteenToEighteen(card); 
var len = card.length; 
if(len == '18') 
{ 
var arrInt = new Array(7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2); 
var arrCh = new Array('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)) 
{ 
return true; 
} 
return false; 
} 
return false; 
}; 

//15位转18位身份证号 
changeFivteenToEighteen = function(card) 
{ 
if(card.length == '15') 
{ 
var arrInt = new Array(7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2); 
var arrCh = new Array('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; 
};

以上就是本文的全部内容,希望对大家实现javascript身份证校验有所帮助。

Javascript 相关文章推荐
最简单的jQuery程序 入门者学习
Jul 09 Javascript
Jquey拖拽控件Draggable使用方法(asp.net环境)
Sep 28 Javascript
JavaScript避免代码的重复执行经验技巧分享
Apr 17 Javascript
一个JavaScript获取元素当前高度的实例
Oct 29 Javascript
js与jQuery实现checkbox复选框全选/全不选的方法
Jan 05 Javascript
javascript中FOREACH数组方法使用示例
Mar 01 Javascript
AngularJS 2.0入门权威指南
Oct 08 Javascript
Vue.js绑定HTML class数组语法错误的原因分析
Oct 19 Javascript
微信小程序3D轮播实现代码
Sep 19 Javascript
vue keep-alive 动态删除组件缓存的例子
Nov 04 Javascript
解决小程序无法触发SESSION问题
Feb 03 Javascript
jQuery--遍历操作实例小结【后代、同胞及过滤】
May 22 jQuery
使用jQuery判断Div是否在可视区域的方法 判断div是否可见
Feb 17 #Javascript
Bootstrap布局组件应用实例讲解
Feb 17 #Javascript
深入php面向对象、模式与实践
Feb 16 #Javascript
三个js循环的关键字示例(for与while)
Feb 16 #Javascript
解析Node.js异常处理中domain模块的使用方法
Feb 16 #Javascript
jQuery Timelinr实现垂直水平时间轴插件(附源码下载)
Feb 16 #Javascript
深入浅析AngularJS和DataModel
Feb 16 #Javascript
You might like
用phpmyadmin更改mysql5.0登录密码
2008/03/25 PHP
PHP开发的一些注意点总结
2010/10/12 PHP
Avengerls vs KG BO3 第三场2.18
2021/03/10 DOTA
javascript实现的基于金山词霸网络翻译的代码
2010/01/15 Javascript
Jquery在指定DIV加载HTML示例代码
2014/02/17 Javascript
js判断字符长度及中英文数字等
2014/03/19 Javascript
Javascript字符串常用方法详解
2016/07/21 Javascript
js实现html table 行,列锁定的简单实例
2016/10/13 Javascript
jQuery实现QQ空间汉字转拼音功能示例
2017/07/10 jQuery
基于Vue实例对象的数据选项
2017/08/09 Javascript
react-native DatePicker日期选择组件的实现代码
2017/09/12 Javascript
详解angular2如何手动点击特定元素上的点击事件
2018/10/16 Javascript
react 应用多入口配置及实践总结
2018/10/17 Javascript
nodejs实现的http、https 请求封装操作示例
2020/02/06 NodeJs
JS内置对象和Math对象知识点详解
2020/04/03 Javascript
React实现评论的添加和删除
2020/10/20 Javascript
JavaScript实现通讯录功能
2020/12/27 Javascript
[00:09]DOTA2新版本PA至宝特效动作展示
2014/11/19 DOTA
Python打印斐波拉契数列实例
2015/07/07 Python
Python中eval带来的潜在风险代码分析
2017/12/11 Python
利用pandas向一个csv文件追加写入数据的实现示例
2020/04/23 Python
Java如何基于wsimport调用wcf接口
2020/06/17 Python
python代码实现图书管理系统
2020/11/30 Python
Python入门基础之数字字符串与列表
2021/02/01 Python
捷克家电和家具购物网站:OKAY.cz
2020/07/23 全球购物
手工社团活动方案
2014/02/17 职场文书
个人授权委托书范本
2014/04/03 职场文书
公司新人试用期自我评价
2014/09/17 职场文书
大四优秀党员个人民主评议
2014/09/19 职场文书
欢迎词怎么写
2015/01/23 职场文书
人才市场接收函
2015/01/30 职场文书
2015年第十五个全民国防教育日宣传活动方案
2015/05/06 职场文书
地道战观后感500字
2015/06/04 职场文书
python3 hdf5文件 遍历代码
2021/05/19 Python
Kubernetes中Deployment的升级与回滚
2022/04/01 Servers
如何用H5实现好玩的2048小游戏
2022/07/23 HTML / CSS