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 相关文章推荐
jquery插件 cluetip 关键词注释
Jan 12 Javascript
ajax 缓存 问题 requestheader
Aug 01 Javascript
jQuery之网页换肤实现代码
Apr 30 Javascript
jquery里的正则表达式说明
Aug 03 Javascript
JQuery里面的几种选择器 查找满足条件的元素$(&quot;#控件ID&quot;)
Aug 23 Javascript
javascript中的循环语句for语句深入理解
Apr 04 Javascript
js实现格式化金额,字符,时间的方法
Feb 26 Javascript
深入理解AngularJs-scope的脏检查(一)
Jun 19 Javascript
深入浅析Node.js单线程模型
Jul 10 Javascript
360doc网站不登录就无法复制内容的解决方法
Jan 27 Javascript
vue两个组件间值的传递或修改方式
Jul 04 Javascript
支付宝小程序自定义弹窗dialog插件的实现代码
Nov 30 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 URL编码解码函数代码
2009/03/10 PHP
php数组转换js数组操作及json_encode的用法详解
2013/10/26 PHP
php实现的支持imagemagick及gd库两种处理的缩略图生成类
2014/09/23 PHP
php实现检查文章是否被百度收录
2015/01/27 PHP
利用Laravel事件系统如何实现登录日志的记录详解
2017/05/20 PHP
dojo 之基础篇(二)之从服务器读取数据
2007/03/24 Javascript
Json对象与Json字符串互转(4种转换方式)
2013/03/27 Javascript
javascript 上下banner替换具体实现
2013/11/14 Javascript
php is_numberic函数造成的SQL注入漏洞
2014/03/10 Javascript
Js获取图片原始宽高的实现代码
2016/05/17 Javascript
JavaScript判断数组是否存在key的简单实例
2016/08/03 Javascript
vue.js组件之间传递数据的方法
2017/07/10 Javascript
axios中cookie跨域及相关配置示例详解
2017/12/20 Javascript
jQuery中图片展示插件highslide.js的简单dom
2018/04/22 jQuery
jQuery中将json数据显示到页面表格的方法
2018/05/27 jQuery
JavaScript使用闭包模仿块级作用域操作示例
2019/01/21 Javascript
this.$toast() 了解一下?
2019/04/18 Javascript
Vue.extend实现挂载到实例上的方法
2019/05/01 Javascript
[03:42]2018完美盛典-《加冕》
2018/12/16 DOTA
Python 字符串操作实现代码(截取/替换/查找/分割)
2013/06/08 Python
Python中字符串格式化str.format的详细介绍
2017/02/17 Python
python递归实现快速排序
2018/08/18 Python
PyQt5 多窗口连接实例
2019/06/19 Python
Pyqt5实现英文学习词典
2019/06/24 Python
Python学习笔记之函数的参数和返回值的使用
2019/11/20 Python
Python timeit模块的使用实践
2020/01/13 Python
用python查找统一局域网下ip对应的mac地址
2021/01/13 Python
如何用Python徒手写线性回归
2021/01/25 Python
瑞士香水购物网站:Parfumcity.ch
2017/01/14 全球购物
介绍一下OSI七层模型
2012/07/03 面试题
公司办公室岗位职责
2014/03/19 职场文书
优秀学生干部个人事迹材料
2014/06/02 职场文书
装饰工程师岗位职责
2014/06/08 职场文书
2016年植树节红领巾广播稿
2015/12/17 职场文书
2016教师暑期培训学习心得体会
2016/01/09 职场文书
python实现简单反弹球游戏
2021/04/12 Python