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实现全选、全不选以及单选功能
Mar 23 jQuery
jQuery实现文章图片弹出放大效果
Apr 06 jQuery
jquery实现异步加载图片(懒加载图片一种方式)
Apr 24 jQuery
jQuery返回定位插件详解
May 15 jQuery
jQuery简单实现向列表动态添加新元素的方法示例
Dec 25 jQuery
jQuery+Cookie实现切换皮肤功能【附源码下载】
Mar 25 jQuery
jQuery简单判断值是否存在于数组中的方法示例
Apr 17 jQuery
详解使用jQuery.i18n.properties实现js国际化
May 04 jQuery
jQuery模拟12306城市选择框功能简单实现方法示例
Aug 13 jQuery
jQuery实现鼠标移入移出事件切换功能示例
Sep 06 jQuery
jquery拖拽自动排序插件使用方法详解
Jul 20 jQuery
jQuery中实现text()的方法
Apr 04 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
php 传值赋值与引用赋值的区别
2010/12/29 PHP
php 连接mysql连接被重置的解决方法
2011/02/15 PHP
探讨php中header的用法详解
2013/06/07 PHP
php结合js实现点击超链接执行删除确认操作
2014/10/31 PHP
php表单提交实例讲解
2015/11/12 PHP
js下获取div中的数据的原理分析
2010/04/07 Javascript
jquery实现在页面加载完毕后获取图片高度或宽度
2014/06/16 Javascript
一个支付页面DEMO附截图
2014/07/22 Javascript
jQuery/CSS3图片特效插件整理推荐
2014/12/07 Javascript
jQuery EasyUi 验证功能实例解析
2017/01/06 Javascript
javascript自执行函数
2017/02/10 Javascript
AngularJs定时器$interval 和 $timeout详解
2017/05/25 Javascript
利用JavaScript对中文(汉字)进行排序实例详解
2017/06/18 Javascript
AngularJS 实现购物车全选反选功能
2017/10/24 Javascript
angular4 共享服务在多个组件中数据通信的示例
2018/03/30 Javascript
jQuery插件Validation表单验证详解
2018/05/26 jQuery
JavaScript canvas仿代码流瀑布
2020/02/10 Javascript
[01:24]DOTA2上海特锦赛OG战队抵达 专车接机入驻总统套房
2016/02/23 DOTA
python基础教程之简单入门说明(变量和控制语言使用方法)
2014/03/25 Python
跟老齐学Python之复习if语句
2014/10/02 Python
python中利用Future对象回调别的函数示例代码
2017/09/07 Python
python闭包与引用以及需要注意的陷阱
2020/09/18 Python
python中strip(),lstrip(),rstrip()函数的使用讲解
2020/11/17 Python
css3中less实现文字长阴影(long shadow)
2020/04/24 HTML / CSS
HTML5表格_动力节点Java学院整理
2017/07/11 HTML / CSS
英国女性时尚鞋类的潮流制造者:Koi Footwear
2018/10/19 全球购物
行政专员工作职责
2013/12/22 职场文书
工厂会计员职责
2014/02/06 职场文书
个人授权委托书范本
2014/04/03 职场文书
优秀学生党员先进事迹材料
2014/05/29 职场文书
灵山大佛导游词
2015/02/04 职场文书
学校2015年纠风工作总结
2015/05/15 职场文书
六种css3实现的边框过渡效果
2021/04/22 HTML / CSS
详解JavaScript中的执行上下文及调用堆栈
2021/04/29 Javascript
MongoDB数据库常用的10条操作命令
2021/06/18 MongoDB
Node-Red实现MySQL数据库连接的方法
2021/08/07 MySQL