博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
最严格的身份证校验(JavaScript版)
阅读量:6077 次
发布时间:2019-06-20

本文共 2421 字,大约阅读时间需要 8 分钟。

      在JavaWeb研发过程中为了获取有效的用户信息,校验其数据的有效性非常是必要,以下贴出在项目中用到的关于身份证的校验:

      <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">

      <html>
            <head>
                  <meta http-equiv="Content-Type" content="text/html; charset=gb2312"/>
                  <title>身份证校验</title>
                  <script type="text/javascript" src="./jquery-1.6.2.js"></script>
                  <script type="text/javascript">
                        function checkCertificateNo(){
                              var certificateNo = $("#certificateNo").val();//身份证号码
                              if(certificateNo.length != 18){
                                    alert("身份证号码无效,请使用第二代身份证!!!"); 
                              }else{
                                    var address = certificateNo.substring(0,6);//6位,地区代码
                                    var birthday = certificateNo.substring(6,14);//8位,出生日期
                                    var sequenceCode =  certificateNo.substring(14,17);//3位,顺序码:奇为男,偶为女
                                    var checkCode =  certificateNo.substring(17);//1位,校验码:检验位
                                    console.log("身份证号码:"+certificateNo+"、地区代码:"+address+"、出生日期:"+birthday+"、顺序码:"+sequenceCode+"、校验码:"+checkCode);
                                    var province={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:"国外"};
                                    var year =  birthday.substring(0,4);   
                                    var month = birthday.substring(4,6);   
                                    var day = birthday.substring(6);
                                    var tempDate = new Date(year,parseFloat(month)-1,parseFloat(day)); 
                                    if(province[parseInt(address.substr(0,2))] == null || (tempDate.getFullYear()!=parseFloat(year) || tempDate.getMonth()!=parseFloat(month)-1 || tempDate.getDate()!=parseFloat(day))){//这里用getFullYear()获取年份,避免千年虫问题
                                          alert("身份证号码无效,请又一次输入!!!");
                                    }else{
                                          var weightedFactors = [ 7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2, 1 ];//加权因子   
                                          var valideCode = [ 1, 0, 10, 9, 8, 7, 6, 5, 4, 3, 2 ];// 身份证验证位值,当中10代表X
                                          var certificateNoArray =certificateNo.split("");// 得到身份证数组
                                          var sum = 0;// 声明加权求和变量
                                          if (certificateNoArray[17].toLowerCase() == 'x') {
                                                certificateNoArray[17] = 10;// 将最后位为x的验证码替换为10  
                                          }
                                         for ( var i = 0; i < 17; i++) {
                                               sum += weightedFactors[i] * certificateNoArray[i];// 加权求和   
                                        }
                                        valCodePosition = sum % 11;// 得到验证码所在位置
                                       if (certificateNoArray[17] == valideCode[valCodePosition]) {
                                              var sex = "男";
                                             if(sequenceCode%2==0){
                                                    sex = "女";
                                              }
                                             alert("身份证号码有效,性别为:"+sex+"!");
                                        } else {
                                             alert("身份证号码无效,请又一次输入!!!");
                                        }
                                   }
                             }
                        }
                   </script>
            </head>
            <body>
                  <input id = "certificateNo" name = "certificateNo" value = "
61072919761109762X"/> &nbsp;&nbsp;&nbsp;<input type="button" οnclick="checkCertificateNo();" value = "開始校验"/>
            </body>
</html>

转载地址:http://yuxgx.baihongyu.com/

你可能感兴趣的文章
无废话WPF系列7:WPF布局控件
查看>>
SharePoint 2013 开发——CSOM概要
查看>>
Android -- 加载大图片的方法
查看>>
Jmeter调试工具---HTTP Mirror Server
查看>>
[软件推荐]jQuery,JavaScript,HTML,CSS,PHP,MySQL,正则表达式 CHM帮助手册
查看>>
Java打war包、jar包
查看>>
Blend 3状态为空的解决方法
查看>>
LeetCode My Solution: Minimum Depth of Binary Tree
查看>>
Silverlight实用窍门系列:57.Silverlight中的Binding使用(二)-数据验证
查看>>
破万。
查看>>
Spark SQL概念学习系列之如何使用 Spark SQL(六)
查看>>
Linux VFS中write系统调用实现原理【转】
查看>>
LocalReport Print with C# C#打印RDLC
查看>>
Android -- 获取汉字的首字母
查看>>
最大长方形 (Maximum Submatrix & Largest Rectangle)(涵盖各种求最大矩形题目)
查看>>
C#设置窗体打开位置(在显示器的右下角打开)
查看>>
网易邮箱繁体字信件乱码解决
查看>>
大叔也说Xamarin~Android篇~调用远程API接口,发POST请求
查看>>
ASP.NET配置错误页面浅析
查看>>
OAuth2授权原理
查看>>