JavaScript实现身份证验证代码实例


Posted in Javascript onAugust 26, 2019

这篇文章主要介绍了JavaScript实现身法证验证代码实例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下

function isIdCardNo(num) {
        num = num.toUpperCase();      //身份证号码为15位或者18位,15位时全为数字,18位前17位为数字,最后一位是校验位,可能为数字或字符X。    
        if (!(/(^\d{15}$)|(^\d{17}([0-9]|X)$)/.test(num))) {
          //alert('输入的身份证号长度不对,或者号码不符合规定!\n15位号码应全为数字,18位号码末位可以为数字或X。');       
          //alert('身份证号长度不正确或不符合规定!');       
          return false;    
        } 
        //验证前2位,城市符合
        var aCity={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:"国外"};
        if(aCity[parseInt(num.substr(0,2))]==null){
          //alert('身份证号不正确或不符合规定!');
          return false;
        }
        //alert('城市:'+aCity[parseInt(num.substr(0,2))]);
        
        //下面分别分析出生日期和校验位
        var len, re; len = num.length; 
        if (len == 15) {
          re = new RegExp(/^(\d{6})(\d{2})(\d{2})(\d{2})(\d{3})$/);
          var arrSplit = num.match(re); //检查生日日期是否正确
          var dtmBirth = new Date('19' + arrSplit[2] + '/' + arrSplit[3] + '/' + arrSplit[4]);
          var bGoodDay; bGoodDay = (dtmBirth.getYear() == Number(arrSplit[2])) && ((dtmBirth.getMonth() + 1) == Number(arrSplit[3])) && (dtmBirth.getDate() == Number(arrSplit[4]));
          if (!bGoodDay) {    
            //alert('身份证号的出生日期不对!');      
            return false;
          } else { //将15位身份证转成18位 //校验位按照ISO 7064:1983.MOD 11-2的规定生成,X可以认为是数字10。    
            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 nTemp = 0, i;      
            num = num.substr(0, 6) + '19' + num.substr(6, num.length - 6);     
            for(i = 0; i < 17; i ++) {        
              nTemp += num.substr(i, 1) * arrInt[i];    
            }
            num += arrCh[nTemp % 11];
            return true;
          }
        }
        if (len == 18) {
          re = new RegExp(/^(\d{6})(\d{4})(\d{2})(\d{2})(\d{3})([0-9]|X)$/);
          var arrSplit = num.match(re); //检查生日日期是否正确
          var dtmBirth = new Date(arrSplit[2] + "/" + arrSplit[3] + "/" + arrSplit[4]);
          var bGoodDay; bGoodDay = (dtmBirth.getFullYear() == Number(arrSplit[2])) && ((dtmBirth.getMonth() + 1) == Number(arrSplit[3])) && (dtmBirth.getDate() == Number(arrSplit[4]));
          if (!bGoodDay) {
            //alert(dtmBirth.getYear());
            //alert(arrSplit[2]);
            //alert('身份证号的出生日期不对!');
            return false;
          }
          else { //检验18位身份证的校验码是否正确。 //校验位按照ISO 7064:1983.MOD 11-2的规定生成,X可以认为是数字10。
            var valnum;
            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 nTemp = 0, i;
            for(i = 0; i < 17; i ++) {
              nTemp += num.substr(i, 1) * arrInt[i];
            }
            valnum = arrCh[nTemp % 11];
            if (valnum != num.substr(17, 1)) {
              //alert('18位身份证的校验码不正确!应该为:' + valnum);
              //alert('18位身份证号的校验码不正确!');
              return false;
            }
            return true;
          }
        } 
        return false;
      };

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
js 获取子节点函数 (兼容FF与IE)
Apr 18 Javascript
关于用Jquery的height()、width()计算动态插入的IMG标签的宽高的问题
Dec 08 Javascript
文本框文本自动补全效果示例分享
Jan 19 Javascript
js正则表达式中test,exec,match方法的区别说明
Jan 29 Javascript
jQuery中:has选择器用法实例
Dec 30 Javascript
jQuery中ready事件用法实例
Jan 19 Javascript
详解Bootstrap glyphicons字体图标
Jan 04 Javascript
jQuery控制div实现随滚动条滚动效果
Jun 07 Javascript
angularjs中$http异步上传Excel文件方法
Feb 23 Javascript
javascript的delete运算符知识点总结
Nov 19 Javascript
Javascript查看大图功能代码实现
May 07 Javascript
JS setTimeout与setInterval的区别
Apr 20 Javascript
基于vue、react实现倒计时效果
Aug 26 #Javascript
tweenjs缓动算法的使用实例分析
Aug 26 #Javascript
JS实现利用闭包判断Dom元素和滚动条的方向示例
Aug 26 #Javascript
JS实现提示效果弹出及延迟隐藏的功能
Aug 26 #Javascript
小程序实现层叠卡片滑动效果
Aug 26 #Javascript
微信小程序 数据缓存实现方法详解
Aug 26 #Javascript
使用typescript构建Vue应用的实现
Aug 26 #Javascript
You might like
PHP 解决session死锁的方法
2013/06/20 PHP
php中session定期自动清理的方法
2015/11/12 PHP
PHP入门教程之上传文件实例详解
2016/09/11 PHP
CI(CodeIgniter)框架视图中加载视图的方法
2017/03/24 PHP
自制PHP框架之路由与控制器
2017/05/07 PHP
PHP日期和时间函数的使用示例详解
2020/08/06 PHP
json跟xml的对比分析
2008/06/10 Javascript
javascript检测浏览器的缩放状态实现代码
2014/09/28 Javascript
让html页面不缓存js的实现方法
2014/10/31 Javascript
jQuery给动态添加的元素绑定事件的方法
2015/03/09 Javascript
jquery实现简单的表单验证
2015/11/17 Javascript
十大热门的JavaScript框架和库
2017/03/21 Javascript
JS伪继承prototype实现方法示例
2018/06/20 Javascript
Next.js实现react服务器端渲染的方法示例
2019/01/06 Javascript
ionic3双击返回退出应用的方法
2019/09/17 Javascript
Vue中通过属性绑定为元素绑定style行内样式的实例代码
2020/04/30 Javascript
微信小程序自定义联系人弹窗
2020/05/26 Javascript
详解JavaScript的this指向和绑定
2020/09/08 Javascript
python中requests和https使用简单示例
2018/01/18 Python
caffe binaryproto 与 npy相互转换的实例讲解
2018/07/09 Python
Python中的单行、多行、中文注释方法
2018/07/19 Python
利用Python将数值型特征进行离散化操作的方法
2018/11/06 Python
Centos部署django服务nginx+uwsgi的方法
2019/01/02 Python
python烟花效果的代码实例
2020/02/25 Python
python 如何调用远程接口
2020/09/11 Python
英国天然保健品网站:Simply Supplements
2017/03/22 全球购物
美国在线眼镜商城:Eyeglasses.com
2017/06/26 全球购物
可持续木材、生态和铝制太阳镜:Proof Eyewear
2019/07/24 全球购物
控制工程专业个人求职信
2013/09/25 职场文书
医学专业大学生求职的自我评价
2013/11/27 职场文书
高二美术教学反思
2014/01/14 职场文书
学校大课间活动方案
2014/01/30 职场文书
法制宣传月活动总结
2014/04/29 职场文书
学校禁毒宣传活动总结
2015/05/08 职场文书
Vue自定义铃声提示音组件的实现
2022/01/22 Vue.js
asyncio异步编程之Task对象详解
2022/03/13 Python