使用js验证身份证号格式以及身份证号中的生日验证

由于不管是测试项目练手还是实际项目开发,都应该考虑数据的严密性和软件的通俗易懂的实用性,下面是我用js实现的验证身份证号格式以及身份证号中的生日验证代码

  //生日移出点击事件验证身份证号中的生日验证

        $("#DateBirth").blur(function checkIdAndBirthday(strId,strBrithday){

            var strBrithday = $("#DateBirth").val();

            var strId = $("#IDNumber").val();

            var dateTemp= new Date() ;

            if(strBrithday != ""){

                var arr_date = strBrithday.split("-");

                var inputDate = new Date(arr_date[0],arr_date[1]-1,arr_date[2]);

                if(inputDate > dateTemp){

                    alert("出生日期时间不能大于今天!请检查!");

                    return false;

                }

                //15位身份证

                if(strId.length == 15){

                    //从ID NO 中截取生日6位数字,前面加上19

                    var idBirthday = "19"+strId.substr(6,6);

                    //日期字符串中的8位生日数字

                    var textBirthday = arr_date[0]+arr_date[1]+arr_date[2];

                    if(idBirthday == textBirthday){

                        return true;

                    }else{

                        alert("出生日期与身份证日期不一致,请检查!");

                        return false;

                    }              

                }

                //18位身份证

                if(strId.length == 18){

                    //从ID NO 中截取生日8位数字

                    var idBirthday = strId.substr(6,8);

                    //日期字符串中的8位生日数字

                    var textBirthday = arr_date[0]+arr_date[1]+arr_date[2];

                    //alert(idBirthday);

                    //alert(textBirthday);

                    if(idBirthday == textBirthday){

                        return true;

                    }else{

                        alert("出生日期与身份证日期不一致,请检查!");

                        return false;

                    }

                }

            }

            return true;

        })

 

 

 //验证身份证证件号格式

        $("#IDNumber").blur(function () {

            var a = $("#IDNumber").val();

        

            var textIDNumber = /^[1-9]{1}[0-9]{14}$|^[1-9]{1}[0-9]{16}([0-9]|[xX])$/;

          

            if (textIDNumber.test(a)) {

 return true;

            } else {

                alert("身份证证件号格式有误!");

 return false;

            }

        })

   若看完不能给您带来帮助,肯定是我表达不够明了不够清晰,请多多指教,多多谅解,谢谢!

  • 15
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 16
    评论
自己写的比较全js验证,供大家参考 //身份证验证 function checkIdcard(idcard1,showMsg){ var idcard=this.trim(idcard1);// 对身份证号码做处理。去除头尾空格。 var Errors=new Array( "验证通过!", "身份证号码位数不对!", "身份证号码出生日期超出范围或含有非法字符!", "身份证号校验错误!", "身份证地区非法!" ); var area={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 idcard,Y,JYM; var S,M; var idcard_array = new Array(); idcard_array = idcard.split(""); /*基本校验*/ if(idcard == "" || idcard == null || idcard.length == 0) { if(showMsg==null||showMsg=="") alert("身份证号为空,请输入您的身份证号!"); return false; } /*地区检验*/ if(area[parseInt(idcard.substr(0,2))]==null) { if(showMsg==null||showMsg=="") alert(Errors[4]); return false; } /*身份号码位数及格式检验*/ switch(idcard.length){ case 15: if ( (parseInt(idcard.substr(6,2))+1900) % 4 == 0 || ((parseInt(idcard.substr(6,2))+1900) % 100 == 0 && (parseInt(idcard.substr(6,2))+1900) % 4 == 0 )){ ereg=/^[1-9][0-9]{5}[0-9]{2}((01|03|05|07|08|10|12)(0[1-9]|[1-2][0-9]|3[0-1])|(04|06|09|11)(0[1-9]|[1-2][0-9]|30)|02(0[1-9]|[1-2][0-9]))[0-9]{3}$/;//测试出生日期的合法性 } else { ereg=/^[1-9][0-9]{5}[0-9]{2}((01|03|05|07|08|10|12)(0[1-9]|[1-2][0-9]|3[0-1])|(04|06|09|11)(0[1-9]|[1-2][0-9]|30)|02(0[1-9]|1[0-9]|2[0-8]))[0-9]{3}$/;//测试出生日期的合法性 } if(ereg.test(idcard)){ //alert(Errors[0]+"15"); return true; //15位验证通过 } else { if(showMsg==null||showMsg=="") alert(Errors[2]); return false; } break; case 18: //18位身份号码检测 //出生日期的合法性检查 //闰年月日:((01|03|05|07|08|10|12)(0[1-9]|[1-2][0-9]|3[0-1])|(04|06

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 16
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

宜春

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值