jquery 校验中国身份证号码实例详解


Posted in jQuery onApril 11, 2017

jquery 校验中国身份证号码实例详解

大陆18位身份证(第二代身份证)

身份号码是一组具有特征组合码,由十七位数字本体码和一位校验码组成。

排列顺序从左至右依次为:六位数字地区码,八位数字生日码,三位数字顺序码和一位数字校验码。

校验方法:

(1)先对前17位数字的权求和

        S = Sum(Ci * Vi), i = 0, ... , 16

        Ci:表示身份证号码上第i位置的数字值

        Vi:表示第i位置上的“加权因子”

        加权因子Vi: 7 9 10 5 8 4 2 1 6 3 7 9 10 5 8 4 2

(2)计算模(固定算法)

        Y = mod(S, 11)

(3)将计算模Y与对应的校验码校验

        Y:        0 1 2 3 4 5 6 7 8 9 10 (通过Y取得对应校验码与身份证的第18位校验)

        校验码: 1 0 X 9 8 7 6 5 4 3 2

实例代码:

function check_id(value){
  var arrExp = [7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2];//加权因子 
  var arrValid = [1, 0, "X", 9, 8, 7, 6, 5, 4, 3, 2];//校验码 
  if(/^\d{17}\d|x$/i.test(value)){  
    var sum = 0, idx; 
    for(var i = 0; i < value.length - 1; i++){ 
      // 对前17位数字与权值乘积求和 
      sum += parseInt(value.substr(i, 1), 10) * arrExp[i]; 
    } 
    // 计算模(固定算法) 
    idx = sum % 11; 
    // 检验第18为是否与校验码相等 
    return arrValid[idx] == value.substr(17, 1).toUpperCase(); 
  }else{ 
    return false; 
  } 
}

感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!

jQuery 相关文章推荐
详谈表单格式化插件jquery.serializeJSON
Jun 23 jQuery
jQuery操作DOM_动力节点Java学院整理
Jul 04 jQuery
基于jQuery实现的单行公告活动轮播效果
Aug 23 jQuery
jQuery+Cookie实现切换皮肤功能【附源码下载】
Mar 25 jQuery
jQuery实现table表格checkbox全选的方法分析
Jul 04 jQuery
jQuery的Ajax接收java返回数据方法
Aug 11 jQuery
jQuery+PHP实现上传裁剪图片
Jun 29 jQuery
jQuery删除/清空指定元素的所有子节点实例代码
Jul 04 jQuery
JQuery复选框全选效果如何实现
May 08 jQuery
jQuery AJAX应用实例总结
May 19 jQuery
Jquery Fade用法详解
Nov 06 jQuery
基于jQuery实现瀑布流页面
Apr 11 #jQuery
jQuery插件FusionCharts绘制的2D双面积图效果示例【附demo源码】
Apr 11 #jQuery
jQuery EasyUI 组件加上“清除”功能实例详解
Apr 11 #jQuery
vue中如何引入jQuery和Bootstrap
Apr 10 #jQuery
jQuery插件FusionCharts绘制2D柱状图和折线图的组合图效果示例【附demo源码】
Apr 10 #jQuery
jQuery插件FusionCharts绘制2D环饼图效果示例【附demo源码】
Apr 10 #jQuery
jQuery EasyUI之验证框validatebox实例详解
Apr 10 #jQuery
You might like
一个查看session内容的函数
2006/10/09 PHP
php正则校验用户名介绍
2008/07/19 PHP
JS 实现双色表格实现代码
2009/11/24 Javascript
js常用代码段整理
2011/11/30 Javascript
Javascript 中的 call 和 apply使用介绍
2012/02/22 Javascript
node.js [superAgent] 请求使用示例
2015/03/13 Javascript
令按钮悬浮在(手机)页面底部的实现方法
2017/05/02 Javascript
详解用vue.js和laravel实现微信授权登陆
2017/06/23 Javascript
原生JavaScript实现Ajax异步请求
2017/11/19 Javascript
基于webpack4+vue-cli3项目实现换肤功能
2019/07/17 Javascript
layer弹出层倒计时关闭的实现方法
2019/09/27 Javascript
element-ui 文件上传修改文件名的方法示例
2019/11/05 Javascript
如何在wxml中直接写js代码(wxs)
2019/11/14 Javascript
vuex分模块后,实现获取state的值
2020/07/26 Javascript
简单谈谈python中的多进程
2016/11/06 Python
详解python中 os._exit() 和 sys.exit(), exit(0)和exit(1) 的用法和区别
2017/06/23 Python
python实现反转部分单向链表
2018/09/27 Python
python日志模块logbook使用方法
2019/09/19 Python
基于Python快速处理PDF表格数据
2020/06/03 Python
CSS3制作半透明边框(Facebox)类似渐变
2012/12/09 HTML / CSS
HTML5中的websocket实现直播功能
2018/05/21 HTML / CSS
函授自我鉴定范文
2014/02/06 职场文书
《孔子游春》教学反思
2014/02/25 职场文书
《识字五》教学反思
2014/03/01 职场文书
征婚广告词
2014/03/17 职场文书
大专生求职信
2014/06/29 职场文书
护士求职信
2014/07/05 职场文书
副主任竞聘演讲稿
2014/08/18 职场文书
党员个人自我剖析材料
2014/10/08 职场文书
房产公证书格式
2015/01/26 职场文书
背起爸爸上学观后感
2015/06/08 职场文书
健康证明
2015/06/19 职场文书
小学运动会通讯稿
2015/07/18 职场文书
中学生运动会广播稿
2015/08/19 职场文书
Python编程super应用场景及示例解析
2021/10/05 Python
Alexa停服!网站排名将何去何从?目前还没有替代品。
2022/04/15 杂记