js身份证判断方法支持15位和18位


Posted in Javascript onMarch 18, 2014
//HTML页面上要有一个id为identity_card的input输入框,一个id为ipmessage的身份证错误或正确时提示消息的地方 
<script> 
//身份证验证 
$(document).ready(function(){ 
$("#identity_card").change(function(){ 
var idcard =$(this).val(); 
checkDate(idcard ); 
}); 
}); 
//身份证 
function checkDate( idcard ){ 
var socialNo = idcard; 
if(socialNo == "") 
{ 
$('#ipmessage').html('输入身份证号码格式不正确,必须是15位到18位的身份证号'); 
alert("输入身份证号码不能为空!"); 
return (false); 
} 
if (socialNo.length != 15 && socialNo.length != 18) 
{ 
$('#ipmessage').html('输入身份证号码格式不正确,必须是15位到18位的身份证号'); 
alert("输入身份证号码格式不正确!"); 
return (false); 
} 
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:"国外"}; 
if(area[parseInt(socialNo.substr(0,2))]==null) { 
$('#ipmessage').html('输入身份证号码格式不正确,必须是15位到18位的身份证号'); 
alert("身份证号码不正确(地区非法)!"); 
return (false); 
} 
if (socialNo.length == 15) 
{ 
pattern= /^\d{15}$/; 
if (pattern.exec(socialNo)==null){ 
$('#ipmessage').html('输入身份证号码格式不正确,必须是15位到18位的身份证号'); 
alert("15位身份证号码必须为数字!"); 
return (false); 
} 
var birth = parseInt("19" + socialNo.substr(6,2)); 
var month = socialNo.substr(8,2); 
var day = parseInt(socialNo.substr(10,2)); 
switch(month) { 
case '01': 
case '03': 
case '05': 
case '07': 
case '08': 
case '10': 
case '12': 
if(day>31) { 
$('#ipmessage').html('输入身份证号码格式不正确,必须是15位到18位的身份证号'); 
alert('输入身份证号码不格式正确!'); 
return false; 
} 
break; 
case '04': 
case '06': 
case '09': 
case '11': 
if(day>30) { 
$('#ipmessage').html('输入身份证号码格式不正确,必须是15位到18位的身份证号'); 
alert('输入身份证号码不格式正确!'); 
return false; 
} 
break; 
case '02': 
if((birth % 4 == 0 && birth % 100 != 0) || birth % 400 == 0) { 
if(day>29) { 
$('#ipmessage').html('输入身份证号码格式不正确,必须是15位到18位的身份证号'); 
alert('输入身份证号码不格式正确!'); 
return false; 
} 
} else { 
if(day>28) { 
$('#ipmessage').html('输入身份证号码格式不正确,必须是15位到18位的身份证号'); 
alert('输入身份证号码不格式正确!'); 
return false; 
} 
} 
break; 
default: 
$('#ipmessage').html('输入身份证号码格式不正确,必须是15位到18位的身份证号'); 
alert('输入身份证号码不格式正确!'); 
return false; 
} 
var nowYear = new Date().getYear(); 
if(nowYear - parseInt(birth)<15 || nowYear - parseInt(birth)>100) { 
$('#ipmessage').html('输入身份证号码格式不正确,必须是15位到18位的身份证号'); 
alert('输入身份证号码不格式正确!'); 
return false; 
} 
$('#ipmessage').html('通过!'); 
return (true); 
} 
var Wi = new Array( 
7,9,10,5,8,4,2,1,6, 
3,7,9,10,5,8,4,2,1 
); 
var lSum = 0; 
var nNum = 0; 
var nCheckSum = 0; 
for (i = 0; i < 17; ++i) 
{ 
if ( socialNo.charAt(i) < '0' || socialNo.charAt(i) > '9' ) 
{ 
$('#ipmessage').html('输入身份证号码格式不正确,必须是15位到18位的身份证号'); 
alert("输入身份证号码格式不正确!"); 
return (false); 
} 
else 
{ 
nNum = socialNo.charAt(i) - '0'; 
} 
lSum += nNum * Wi[i]; 
} 
if( socialNo.charAt(17) == 'X' || socialNo.charAt(17) == 'x') 
{ 
lSum += 10*Wi[17]; 
} 
else if ( socialNo.charAt(17) < '0' || socialNo.charAt(17) > '9' ) 
{ 
$('#ipmessage').html('输入身份证号码格式不正确,必须是15位到18位的身份证号'); 
alert("输入身份证号码格式不正确!"); 
return (false); 
} 
else 
{ 
lSum += ( socialNo.charAt(17) - '0' ) * Wi[17]; 
} 
if ( (lSum % 11) == 1 ) 
{ 
$('#ipmessage').html('通过!'); 
return true; 
} 
else 
{ 
$('#ipmessage').html('输入身份证号码格式不正确,必须是15位到18位的身份证号'); 
alert("输入身份证号码格式不正确!"); 
return (false); 
} 
} 
</script>
Javascript 相关文章推荐
根据分辩率调用不同的CSS.
Jan 08 Javascript
JQuery学习笔记 nt-child的使用
Jan 17 Javascript
JavaScript实现获取dom中class的方法
Feb 09 Javascript
JS实现很酷的EMAIL地址添加功能实例
Feb 28 Javascript
javascript跑马灯抽奖实例讲解
Apr 17 Javascript
Bootstrap下拉菜单效果实例代码分享
Jun 30 Javascript
JavaScript实现的select点菜功能示例
Jan 16 Javascript
jquery对table做排序操作的实例演示
Aug 10 jQuery
[js高手之路]HTML标签解释成DOM节点的实现方法
Aug 31 Javascript
用JavaScript做简易的购物车的代码示例
Oct 20 Javascript
AngularJS 监听变量变化的实现方法
Oct 09 Javascript
基于js实现判断浏览器类型代码实例
Jul 17 Javascript
验证码在IE中不刷新而谷歌等浏览器正常的解决方案
Mar 18 #Javascript
用js将内容复制到剪贴板兼容浏览器
Mar 18 #Javascript
javascript页面上使用动态时间具体实现
Mar 18 #Javascript
JS调用页面表格导出excel示例代码
Mar 18 #Javascript
javascript:window.open弹出窗口的位置问题
Mar 18 #Javascript
js判断iframe内的网页是否滚动到底部触发事件
Mar 18 #Javascript
用jQuery实现的智能隐藏、滑动效果的返回顶部代码
Mar 18 #Javascript
You might like
PHP获取文件的MD5值并判断是否被修改的例子
2014/06/19 PHP
PHP程序员的技术成长规划
2016/03/25 PHP
document 和 document.all 分别什么时候用
2006/06/22 Javascript
JavaScript Date对象 日期获取函数
2010/12/19 Javascript
javascript实现ecshop搜索框键盘上下键切换控制
2015/03/18 Javascript
Javascript编程中几种继承方式比较分析
2015/11/28 Javascript
纯js和css完成贪吃蛇小游戏demo
2016/09/01 Javascript
浅述节点的创建及常见功能的实现
2016/12/15 Javascript
Ajax验证用户名或昵称是否已被注册
2017/04/05 Javascript
在bootstrap中实现轮播图实例代码
2017/06/11 Javascript
Webpack框架核心概念(知识点整理)
2017/12/22 Javascript
vue中的mvvm模式讲解
2019/01/31 Javascript
JavaScript中Dom操作实例详解
2019/07/08 Javascript
Vue+ElementUI table实现表格分页
2019/12/14 Javascript
在Python上基于Markov链生成伪随机文本的教程
2015/04/17 Python
Python实现将SQLite中的数据直接输出为CVS的方法示例
2017/07/13 Python
python执行精确的小数计算方法
2019/01/21 Python
python 定时器,轮询定时器的实例
2019/02/20 Python
python画双y轴图像的示例代码
2019/07/07 Python
windows上安装python3教程以及环境变量配置详解
2019/07/18 Python
python读文件的步骤
2019/10/08 Python
Pytorch之卷积层的使用详解
2019/12/31 Python
解决Jupyter NoteBook输出的图表太小看不清问题
2020/04/16 Python
keras多显卡训练方式
2020/06/10 Python
使用python将微信image下.dat文件解密为.png的方法
2020/11/30 Python
John Varvatos官方网站:设计师男士时装
2017/02/08 全球购物
美国50岁以上单身人士约会平台:SilverSingles
2018/06/29 全球购物
英国领先的游戏零售商:GAME
2019/09/24 全球购物
Ever New美国:澳大利亚领先的女装时尚品牌
2019/11/28 全球购物
大学生个人总结的自我评价
2013/10/05 职场文书
清华大学自主招生自荐信
2014/01/29 职场文书
元宵节主持词
2014/03/25 职场文书
银行内勤岗位职责
2014/04/09 职场文书
计算机求职自荐信范文
2014/04/19 职场文书
2014年政务公开工作总结
2014/12/09 职场文书
瞿秋白纪念馆观后感
2015/06/10 职场文书