javascript实现验证身份证号的有效性并提示
javascript实现验证身份证号的有效性并提示
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;}
使用方法:
<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>
效果为输入身份证号,焦掉移开后自动验证,并返回信息!
以上所述就是本文的全部内容了,希望大家能够喜欢。
javascript实现验证身份证号的有效性并提示的更多相关文章
- JavaScript验证身份证号
<%@ page language="java" contentType="text/html; charset=GB18030" pageEncodin ...
- js验证身份证号,超准确
js验证身份证号,超准确 看程序前先来了解下身份证号的构成:身份证号分为两种,旧的为15位,新的为18位.身份证15位编码规则:dddddd yymmdd xx p 其中 dddddd:地区码 ...
- js正则表达式验证身份证号和密码
//验证身份证号只能输入15位或者18位的身份证号 /^\d{14}[X|\d]{1}$|^\d{18}$/ig //验证只能输入字母和数字组合6到16位 /^[a-z][a-z0-9]{6,16}$ ...
- Android 使用正则表达式验证身份证号是否符合规则
我国当前的身份证号分为三种: 一.15位身份证号 二.18位身份证号(前17位位数字,最后一位为字母x) 三.18为身份证号(18位都是数字) 具体验证请参考下面代码: /** * 验证身份证号是否符 ...
- bootstrap-validator基本使用(自定义验证身份证号和手机号)
<!DOCTYPE html> <html lang="en"> <head> <meta charset="utf-8&quo ...
- js进阶正则表达式15验证身份证号(|符号的使用:var reg=/^\d{17}[\d|X]$|^\d{15}$/)(str的方法substr)
js进阶正则表达式15验证身份证号(|符号的使用:var reg=/^\d{17}[\d|X]$|^\d{15}$/)(str的方法substr) 一.总结 1.|符号的使用:var reg=/^\d ...
- 锋利的js之验证身份证号
我们在做互联网网站时,注册个人资料时,经常要用到身份证号,我们需要对身份证进验证,不然别人随便输个号码就通过,让你感觉这个网站做得很shit. 身份证号是有规则的. 结构和形式 1.号码的结构 公民 ...
- jquery validation验证身份证号、护照、电话号码、email
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...
- 如何用javascript正则表达式验证身份证号码是否合法
在用户注册页面有些需求要求的比较严格,需要对身份证js验证是否合法,通过此功能严格此系统软件,从而过滤到很多水客.下面就此实现方法给大家讲解下. 很多时候我们都是通过一组正则表达式来判断用户输入的身份 ...
随机推荐
- 广告基本知识-ROI分解
任何一个在线广告系统,都面临ROI的问题,对于Invest,我们先不考虑,因为对于流量有多种方式可以买回,也无法优化(当然在RTB的时候是可以优化的).Return是主要优化的方向,Return=点击 ...
- IP地址分类(转)
IP地址分类以及C类IP地址的子网划分 国际规定:把所有的IP地址划分为 A,B,C,D,E A类地址:范围从0-127,0是保留的并且表示所有IP地址,而127也是保留的地址,并且是用于测试环回用的 ...
- VB的写法,关于版本写入注册表
VB的写法,关于版本写入注册表 '软件都有一个关于我们的菜单,单单实现这个功能并不难,困难的是能够将这些信息写入注册表中,这样每次只要弹出这样的窗口,就从注册表里去搜索.这样是不是极大的节省了资源 ...
- create OpenVPN on ubuntu12.04
---恢复内容开始--- 最近比较火的有digitalocean 的SSD VPS,配置还不错.每个月5刀,512MB内存,CPU被虚拟过.不是KVM.链接能量也不大. 节点在西雅图,对环太平洋比较 ...
- memcached 命令操作详解
memcached 命令操作详解 一.存储命令 存储命令的格式: <command name> <key> <flags> <exptime> < ...
- 国外大师给PHP初学者的8条建议
学习一门新语言可能会是一件很艰巨的任务,最好的办法就是借鉴前辈的经验已达到事半功倍,下面就是为php新手们准备的一些经验餐. 1.从OOP开始Naramore是SourceForge员工以及PHPWo ...
- mybatis判断list为空
在传入的map或者对象里面存在一个list,此时想要判断list是否为空,可以 <if test="spids.size()>0 " > and SPid not ...
- Java基础篇Socket网络编程中的应用实例
说到java网络通讯章节的内容,刚入门的学员可能会感到比较头疼,应为Socket通信中一定会伴随有IO流的操作,当然对IO流比较熟练的哥们会觉得这是比较好玩的一章,因为一切都在他们的掌握之中,这样操作 ...
- 结构-行为-样式-AngularJs--指令实现 手动触发响应到页面指定位置
最近工作需要增强用户体验,项目经理说下拉框架用户体验太差,于是乎我开始想了如下指令.这个指令可以让用户点击的时候把下拉或者其他的响应显示的东西不会因为屏幕的滚动而看不见,也就是让用户看见他想看见的. ...
- 01--css编码技巧--css揭秘
一 尽量减少代码重复 1.按钮 #btn { padding: .3em .8em; border: 1px solid #446d88; background: #58a linear-gradie ...