javascript实现根据身份证号读取相关信息


Posted in Javascript onDecember 17, 2014

公民身份号码由六位数字地址码,八位数字出生日期码,三位数字顺序码和一位数字校验码组成。

地址码 前两位表示省,中间两位表示市,后两位表示县

顺序码 表示同一地址码所标识的区域范围内,对同年、月、日出生的人员编定的顺序号。顺序码的奇数分给男性,偶数分给女性。

校验码 是根据前面十七位数字码,按照ISO 7064:1983.MOD 11-2校验码计算出来的检验码。

校验码计算方法:
    1)将前面的身份证号码17位数分别乘以不同的系数,从第一位到第十七位的系数分别为:7 9 10 5 8 4 2 1 6 3 7 9 10 5 8 4 2 ;
    2)将这17位数字和系数相乘的结果相加,用加出来和除以11,得到余数;
    4)余数只可能有0 1 2 3 4 5 6 7 8 9 10这11个数字,其分别对应的最后一位身份证的号码为1 0 X 9 8 7 6 5 4 3 2。

身份证号合法性验证  支持15位和18位身份证号 支持地址编码、出生日期、校验位验证

<div style="padding:20px 40px;">

        <h1 style="font-size:20px;color:#999;">身份证查询</h1>

        <input type="text" placeholder="输入身份证号" id="code">

        <input type="button" value="查询" id="btn">

        <p id="home"><strong>籍    贯:</strong><span></span></p>

        <p id="birthday"><strong>出生日期:</strong><span></span></p>

        <p id="sex"><strong>性    别:</strong><span></span></p>

    </div>

    <script type="text/javascript">

        //去掉字符串头尾空格   

        var home='',birthday='',sex='';

        function trim(str) {   

            return str.replace(/^\s*|\s*$/g, "");   

        }

        //验证身份证

        function IdentityCodeValid(code) {

            code=trim(code);

            var city={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:"澳门"};    

            if(!code || !/^\d{6}(18|19|20)?\d{2}(0[1-9]|1[012])(0[1-9]|[12]\d|3[01])\d{3}(\d|X)$/i.test(code)){

                alert("身份证号格式错误");

                home='',birthday='',sex='';

                return false;

            }

            if(!city[code.substring(0,2)]){

                alert("地址编码错误");

                home='',birthday='',sex='';

                return false;

            }

            if(code.length == 18){    //18位身份证需要验证最后一位校验位

                var codeArr = code.split('');        

                var factor = [ 7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2 ];    //加权因子                

                var parity = [ 1, 0, 'X', 9, 8, 7, 6, 5, 4, 3, 2 ];                        //校验位

                var sum = 0;

                for (var i = 0; i < 17; i++){

                    sum += codeArr[i] * factor[i];

                }

                if(parity[sum % 11] != codeArr[17]){

                    alert("校验位错误");

                    home='',birthday='',sex='';

                    return false;

                }                

            }

            //省份

            home = city[code.substring(0,2)];    

            //生日

            birthday = code.substring(6,10)+'年'+code.substring(10,12)+'月'+code.substring(12,14)+'日';

            //性别

            if(code.length==15){

                sex = code.substring(14,15)%2==0 ? '女':'男';

            }else if(code.length==18){

                sex = code.substring(14,17)%2==0 ? '女':'男';

            }

        }

           //输出结果

        document.querySelector('#btn').onclick=function(){

            var code=document.querySelector('#code').value;

            IdentityCodeValid(code);

            document.querySelector('#home span').innerHTML=home;

            document.querySelector('#birthday span').innerHTML=birthday;

            document.querySelector('#sex span').innerHTML=sex;

        }

    </script>

本文主要是根据公民身份证的规则,读取相关的身份信息,非常方便实用,推荐给大家。

Javascript 相关文章推荐
图片自动缩小 点击放大
Jul 07 Javascript
Javascript中的变量使用说明
May 18 Javascript
javascript分页代码(当前页码居中)
Sep 20 Javascript
jQuery动画效果-slideUp slideDown上下滑动示例代码
Aug 28 Javascript
jQuery中noconflict函数的实现原理分解
Feb 03 Javascript
jquery实现图片上传前本地预览功能
May 10 Javascript
Google 地图获取API Key详细教程
Aug 06 Javascript
AngularJS解决ng界面长表达式(ui-set)的方法分析
Nov 07 Javascript
神级程序员JavaScript300行代码搞定汉字转拼音
May 20 Javascript
Angular4学习笔记router的简单使用
Mar 30 Javascript
jQuery实现的自定义轮播图功能详解
Dec 28 jQuery
vue实现点击按钮切换背景颜色的示例代码
Jun 23 Javascript
node.js中的fs.appendFile方法使用说明
Dec 17 #Javascript
javascript操作数组详解
Dec 17 #Javascript
node.js中的fs.appendFileSync方法使用说明
Dec 17 #Javascript
javascript实现节点(div)名称编辑
Dec 17 #Javascript
node.js中的fs.createReadStream方法使用说明
Dec 17 #Javascript
node.js中的fs.createWriteStream方法使用说明
Dec 17 #Javascript
node.js中的fs.futimesSync方法使用说明
Dec 17 #Javascript
You might like
谏山创故乡大分县日田市水坝将设立《进击的巨人》立艾伦、三笠以及阿尔敏的铜像!
2020/03/06 日漫
一个程序下载的管理程序(四)
2006/10/09 PHP
Php Image Resize图片大小调整的函数代码
2011/01/17 PHP
匹配csdn用户数据库与官方用户的重合度并将重叠部分的用户筛选出来
2011/12/25 PHP
ThinkPHP中数据操作案例分析
2015/09/27 PHP
js文字滚动停顿效果代码
2008/06/28 Javascript
Checbox的操作含已选、未选及判断代码
2013/11/07 Javascript
js判断字符长度及中英文数字等
2014/03/19 Javascript
jQuery+PHP打造滑动开关效果
2014/12/16 Javascript
window.open打开窗口被拦截的快速解决方法
2016/08/04 Javascript
Vue.js每天必学之内部响应式原理探究
2016/09/07 Javascript
JS实现数组去重方法总结(六种方法)
2017/07/14 Javascript
Angular6 正则表达式允许输入部分中文字符
2018/09/10 Javascript
js中的数组对象排序分析
2018/12/11 Javascript
JS获取本地地址及天气的方法实例小结
2019/05/10 Javascript
vue解决花括号数据绑定不成功的问题
2019/10/30 Javascript
ES11新增的这9个新特性,你都掌握了吗
2020/10/15 Javascript
vue移动端下拉刷新和上滑加载
2020/10/27 Javascript
python通过apply使用元祖和列表调用函数实例
2015/05/26 Python
python写入并获取剪切板内容的实例
2018/05/31 Python
Pycharm 设置默认头的图文教程
2019/01/17 Python
Django单元测试工具test client使用详解
2019/08/02 Python
django多文件上传,form提交,多对多外键保存的实例
2019/08/06 Python
Python range、enumerate和zip函数用法详解
2019/09/11 Python
python 使用pygame工具包实现贪吃蛇游戏(多彩版)
2019/10/30 Python
英国殿堂级有机护肤品牌:Rodial
2017/04/17 全球购物
英国最专业的健身器材供应商之一:Best Gym Equipment
2017/12/22 全球购物
触发器(trigger)的功能都有哪些?写出一个触发器的例子
2012/09/17 面试题
绝对经典成功的大学生推荐信
2013/11/08 职场文书
上班早退检讨书
2014/01/09 职场文书
大学生作弊检讨书
2014/09/11 职场文书
先进教师事迹材料
2014/12/16 职场文书
Nginx + consul + upsync 完成动态负载均衡的方法详解
2021/03/31 Servers
Python快速实现一键抠图功能的全过程
2021/06/29 Python
Python 阶乘详解
2021/10/05 Python
Python爬虫网络请求之代理服务器和动态Cookies
2022/04/12 Python