js 验证身份证号

2024-06-06 11:18
文章标签 js 验证 身份证号

本文主要是介绍js 验证身份证号,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

function checkCardId(){ var socialNo = document.getElementById("idcard").value;if(socialNo == "")  {  alert("输入身份证号码不能为空!");  return (false);  }  if (socialNo.length != 15 && socialNo.length != 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) {  alert("身份证号码不正确(地区非法)!");  return (false);  }   if (socialNo.length == 15)  {  pattern= /^\d{15}$/;  if (pattern.exec(socialNo)==null){  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) {  alert('输入身份证号码不格式正确!');  return false;  }  break;  case '04':  case '06':  case '09':  case '11':  if(day>30) {  alert('输入身份证号码不格式正确!');  return false;  }  break;  case '02':  if((birth % 4 == 0 && birth % 100 != 0) || birth % 400 == 0) {  if(day>29) {  alert('输入身份证号码不格式正确!');  return false;  }  } else {  if(day>28) {  alert('输入身份证号码不格式正确!');  return false;  }  }  break;  default:  alert('输入身份证号码不格式正确!');  return false;  }  var nowYear = new Date().getYear();  if(nowYear - parseInt(birth)<15 || nowYear - parseInt(birth)>100) {  alert('输入身份证号码不格式正确!');  return false;  }  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' )  {  alert("输入身份证号码格式不正确!");  return (false);  }  else  {  nNum = socialNo.charAt(i) - '0';  }  var ss = Wi[i];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' )  {  alert("输入身份证号码格式不正确!");  return (false);  }  else  {  lSum += ( socialNo.charAt(17) - '0' ) * Wi[17];  }  if ( (lSum % 11) == 1 )  {  alert("正确!");return true;  }  else  {  alert("身份证号码格式不正确!");  return (false);  }  }

 

<input type="text" id="idcard" size="30" />
&nbsp;&nbsp;
<input type="button" id="btn" οnclick="javascript:checkCardId();" />

 

 

这篇关于js 验证身份证号的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1035957

相关文章

Node.js 中 http 模块的深度剖析与实战应用小结

《Node.js中http模块的深度剖析与实战应用小结》本文详细介绍了Node.js中的http模块,从创建HTTP服务器、处理请求与响应,到获取请求参数,每个环节都通过代码示例进行解析,旨在帮... 目录Node.js 中 http 模块的深度剖析与实战应用一、引言二、创建 HTTP 服务器:基石搭建(一

使用Vue.js报错:ReferenceError: “Vue is not defined“ 的原因与解决方案

《使用Vue.js报错:ReferenceError:“Vueisnotdefined“的原因与解决方案》在前端开发中,ReferenceError:Vueisnotdefined是一个常见... 目录一、错误描述二、错误成因分析三、解决方案1. 检查 vue.js 的引入方式2. 验证 npm 安装3.

Spring Security基于数据库验证流程详解

Spring Security 校验流程图 相关解释说明(认真看哦) AbstractAuthenticationProcessingFilter 抽象类 /*** 调用 #requiresAuthentication(HttpServletRequest, HttpServletResponse) 决定是否需要进行验证操作。* 如果需要验证,则会调用 #attemptAuthentica

JS常用组件收集

收集了一些平时遇到的前端比较优秀的组件,方便以后开发的时候查找!!! 函数工具: Lodash 页面固定: stickUp、jQuery.Pin 轮播: unslider、swiper 开关: switch 复选框: icheck 气泡: grumble 隐藏元素: Headroom

在JS中的设计模式的单例模式、策略模式、代理模式、原型模式浅讲

1. 单例模式(Singleton Pattern) 确保一个类只有一个实例,并提供一个全局访问点。 示例代码: class Singleton {constructor() {if (Singleton.instance) {return Singleton.instance;}Singleton.instance = this;this.data = [];}addData(value)

Node.js学习记录(二)

目录 一、express 1、初识express 2、安装express 3、创建并启动web服务器 4、监听 GET&POST 请求、响应内容给客户端 5、获取URL中携带的查询参数 6、获取URL中动态参数 7、静态资源托管 二、工具nodemon 三、express路由 1、express中路由 2、路由的匹配 3、路由模块化 4、路由模块添加前缀 四、中间件

EasyPlayer.js网页H5 Web js播放器能力合集

最近遇到一个需求,要求做一款播放器,发现能力上跟EasyPlayer.js基本一致,满足要求: 需求 功性能 分类 需求描述 功能 预览 分屏模式 单分屏(单屏/全屏) 多分屏(2*2) 多分屏(3*3) 多分屏(4*4) 播放控制 播放(单个或全部) 暂停(暂停时展示最后一帧画面) 停止(单个或全部) 声音控制(开关/音量调节) 主辅码流切换 辅助功能 屏

C++ | Leetcode C++题解之第393题UTF-8编码验证

题目: 题解: class Solution {public:static const int MASK1 = 1 << 7;static const int MASK2 = (1 << 7) + (1 << 6);bool isValid(int num) {return (num & MASK2) == MASK1;}int getBytes(int num) {if ((num &

C语言 | Leetcode C语言题解之第393题UTF-8编码验证

题目: 题解: static const int MASK1 = 1 << 7;static const int MASK2 = (1 << 7) + (1 << 6);bool isValid(int num) {return (num & MASK2) == MASK1;}int getBytes(int num) {if ((num & MASK1) == 0) {return

easyui同时验证账户格式和ajax是否存在

accountName: {validator: function (value, param) {if (!/^[a-zA-Z][a-zA-Z0-9_]{3,15}$/i.test(value)) {$.fn.validatebox.defaults.rules.accountName.message = '账户名称不合法(字母开头,允许4-16字节,允许字母数字下划线)';return fal