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验证是否合法,通过此功能严格此系统软件,从而过滤到很多水客.下面就此实现方法给大家讲解下. 很多时候我们都是通过一组正则表达式来判断用户输入的身份 ...
随机推荐
- 查看Tomcat版本
在Tomcat的安装目录的bin目录下,有这么两个文件 version.bat windows下的批处理文件 version.sh Linux下的Shell脚本 在DOS窗口执行ver ...
- (转)JS中公共/私有变量和方法
私有变量 在对象内部使用'var'关键字来声明,而且它只能被私有函数和特权方法访问. 私有函数 在对象的构造函数里声明(或者是通过var functionName=function(){...}来定义 ...
- urllib2 源码小剖
urllib2 源码小剖 2013-08-25 23:38 by 捣乱小子, 272 阅读, 0 评论, 收藏, 编辑 两篇小剖已经完成: urllib 源码小剖 urllib2 源码小剖 urlli ...
- mybatis配置Log4j带不出日志
使用Mybatis的时候,有些时候能输出(主要是指sql,参数,结果)日志. 无法输出日志的时候,无论怎么配置log4j,不管是properties的还是xml的,都不起作用. log4j.prope ...
- ios学习笔记(一)之Object-C
一:Objective-C语言基础 二:Objective-C类与继承和协议 一:Objective-C语言基础: 1.1)#import 包含头文件 与#include 作用相同 1.2)Obje ...
- DES加密解密 与 Cookie的封装(C#与js互相加密解密)
2D JS框架 - DES加密解密 与 Cookie的封装(C#与js互相加密解密) 这次实现了JS端的DES加密与解密,并且C#端也能正确解析DES的密文(反之也实现了) 使用的代码如下,非常方 ...
- Socket的粘包处理
Socket的粘包处理 当socket接收到数据后,会根据buffer的大小一点一点的接收数据,比如: 对方发来了1M的数据量过来,但是,本地的buffer只有1024字节,那就代表socket需要重 ...
- Jenkins安装plugin
Jenkins支持很多的plugin,这些plugin极大地丰富了Jenkins的功能.安装plugin有两种方式:自动安装和手动安装. 1.自动安装 这种方式非常简单,但前提是Jenkins必须连接 ...
- 使用HttpWebRequest模拟登陆阿里巴巴(alibaba、httpwebrequest、login)
前言 其实老喜欢取经,偶尔也得分享下.关于阿里巴巴国际站的登陆,过程有点复杂但是算不上难.一不小心少个东西倒也挺麻烦的. 主要是看下请求类HttpClient基本请求封装使用,AliClient模拟浏 ...
- 持续集成CI与自动化测试
-------------------------------------------------------------------------------------------------- ...