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 相关文章推荐
JavaScript 函数式编程的原理
Oct 16 Javascript
被jQuery折腾得半死,揭秘为何jQuery为何在IE/Firefox下均无法使用
Jan 22 Javascript
flexigrid 类似ext grid的JS表格代码
Jul 17 Javascript
jquery应该如何来设置改变按钮input的onclick事件
Dec 10 Javascript
在javascript中实现函数数组的方法
Dec 25 Javascript
在javascript中如何得到中英文混合字符串的长度
Jan 17 Javascript
深入理解JavaScript系列(47):对象创建模式(上篇)
Mar 04 Javascript
基于JavaScript实现在新的tab页打开url
Aug 04 Javascript
jQuery常见的选择器及用法介绍
Dec 20 Javascript
vue获取DOM元素并设置属性的两种实现方法
Sep 30 Javascript
解决Vue+Electron下Vuex的Dispatch没有效果问题
May 20 Javascript
JS原型对象操作实例分析
Jun 06 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 include加载文件两种方式效率比较
2010/08/08 PHP
PHP四舍五入、取整、round函数使用示例
2015/02/06 PHP
Redis使用Eval多个键值自增的操作实例
2016/11/04 PHP
laravel实现图片上传预览,及编辑时可更换图片,并实时变化的例子
2019/11/14 PHP
JQuery 操作select标签实现代码
2010/05/14 Javascript
JavaScript学习笔记之获取当前目录的实现代码
2010/12/14 Javascript
用jquery和json从后台获得数据集的代码
2011/11/07 Javascript
用jquery写的菜单从左往右滑动出现
2014/04/11 Javascript
浅谈JavaScript Date日期和时间对象
2014/12/29 Javascript
jQuery结合CSS制作漂亮的select下拉菜单
2015/05/03 Javascript
Linux下为Node.js程序配置MySQL或Oracle数据库的方法
2016/03/19 Javascript
使用JavaScript实现ajax的实例代码
2016/05/11 Javascript
Node.js的Koa框架上手及MySQL操作指南
2016/06/13 Javascript
js生成随机数方法和实例
2017/01/17 Javascript
vue自定义全局组件(自定义插件)的用法
2018/01/30 Javascript
nginx部署访问vue-cli搭建的项目的方法
2018/02/12 Javascript
Vue使用mixins实现压缩图片代码
2018/03/14 Javascript
Jquery动态列功能完整实例
2019/08/30 jQuery
vue动态子组件的两种实现方式
2019/09/01 Javascript
[02:54]DOTA2亚洲邀请赛 VG战队出场宣传片
2015/02/07 DOTA
[05:53]敌法师的金色冠名ID"BurNIng",是传说,是荣耀
2020/07/11 DOTA
python自动化测试之连接几组测试包实例
2014/09/28 Python
Python下载指定页面上图片的方法
2016/05/12 Python
Python简单获取自身外网IP的方法
2016/09/18 Python
python中numpy.zeros(np.zeros)的使用方法
2017/11/07 Python
python使用jieba实现中文分词去停用词方法示例
2018/03/11 Python
Python 变量的创建过程详解
2019/09/02 Python
Python3如何在Windows和Linux上打包
2020/02/25 Python
python3.8.1+selenium实现登录滑块验证功能
2020/05/22 Python
Python如何实现Paramiko的二次封装
2021/01/30 Python
用React加CSS3实现微信拆红包动画效果
2017/03/13 HTML / CSS
html5响应式开发自动计算fontSize的方法
2020/01/13 HTML / CSS
自我鉴定200字
2013/10/28 职场文书
优秀毕业自我鉴定
2014/02/15 职场文书
民族学专业职业生涯规划范文:积跬步以至千里
2014/09/11 职场文书
小班上学期幼儿评语
2014/12/30 职场文书