·您当前的位置:首页 > 技术教程 > JavaScript >

[JS]身份证判断与查询功能的实例源代码

时间:2015-12-09 11:54酷播
[JS]身份证判断与查询功能的实例源代码

[JS]身份证判断与查询功能的实例源代码

  1. <div style="padding:20px 40px;"> 
  2.     <h1 style="font-size:20px;color:#999;">身份证查询</h1> 
  3.     <input type="text" placeholder="输入身份证号" id="code"> 
  4.     <input type="button" value="查询" id="btn"> 
  5.     <p id="home"><strong>籍&nbsp;&nbsp;&nbsp;&nbsp;贯:</strong><span></span></p> 
  6.     <p id="birthday"><strong>出生日期:</strong><span></span></p> 
  7.     <p id="sex"><strong>性&nbsp;&nbsp;&nbsp;&nbsp;别:</strong><span></span></p> 
  8. </div> 
  9. <script type="text/javascript"> 
  10.     /*  
  11.     公民身份号码由六位数字地址码,八位数字出生日期码,三位数字顺序码和一位数字校验码组成。 
  12.     地址码 前两位表示省,中间两位表示市,后两位表示县 
  13.     顺序码 表示同一地址码所标识的区域范围内,对同年、月、日出生的人员编定的顺序号。顺序码的奇数分给男性,偶数分给女性。 
  14.     校验码 是根据前面十七位数字码,按照ISO 7064:1983.MOD 11-2校验码计算出来的检验码。 
  15.     校验码计算方法: 
  16.         1)将前面的身份证号码17位数分别乘以不同的系数,从第一位到第十七位的系数分别为:7 9 10 5 8 4 2 1 6 3 7 9 10 5 8 4 2 ; 
  17.         2)将这17位数字和系数相乘的结果相加,用加出来和除以11,得到余数; 
  18.         4)余数只可能有0 1 2 3 4 5 6 7 8 9 10这11个数字,其分别对应的最后一位身份证的号码为1 0 X 9 8 7 6 5 4 3 2。 
  19.  
  20.     身份证号合法性验证  支持15位和18位身份证号 支持地址编码、出生日期、校验位验证  
  21.     */ 
  22.  
  23.     //CuPlayer.com去掉字符串头尾空格    
  24.     var home='',birthday='',sex=''
  25.     function trim(str) {    
  26.         return str.replace(/^\s*|\s*$/g, "");    
  27.     } 
  28.     //CuPlayer.com验证身份证 
  29.     function IdentityCodeValid(code) { 
  30.         code=trim(code); 
  31.         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:"澳门"};     
  32.  
  33.         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)){ 
  34.             alert("身份证号格式错误"); 
  35.             home='',birthday='',sex=''
  36.             return false; 
  37.         } 
  38.         if(!city[code.substring(0,2)]){ 
  39.             alert("地址编码错误"); 
  40.             home='',birthday='',sex=''
  41.             return false; 
  42.         } 
  43.         if(code.length == 18){    //18位身份证需要验证最后一位校验位 
  44.             var codecodeArr = code.split('');         
  45.             var factor = [ 7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2 ];    //加权因子                 
  46.             var parity = [ 1, 0, 'X', 9, 8, 7, 6, 5, 4, 3, 2 ];                        //校验位 
  47.             var sum = 0
  48.             for (var i = 0; i < 17; i++){ 
  49.                 sum += codeArr[i] * factor[i]; 
  50.             } 
  51.             if(parity[sum % 11] != codeArr[17]){ 
  52.                 alert("校验位错误"); 
  53.                 home='',birthday='',sex=''
  54.                 return false; 
  55.             }                 
  56.         } 
  57.         //CuPlayer.com省份 
  58.         home = city[code.substring(0,2)];     
  59.         //生日 
  60.         birthday = code.substring(6,10)+'年'+code.substring(10,12)+'月'+code.substring(12,14)+'日'; 
  61.         //性别 
  62.         if(code.length==15){ 
  63.             sex = code.substring(14,15)%2==0 ? '女':'男'; 
  64.         }else if(code.length==18){ 
  65.             sex = code.substring(14,17)%2==0 ? '女':'男'; 
  66.         } 
  67.     } 
  68.        //CuPlayer.com输出结果 
  69.     document.querySelector('#btn').onclick=function(){ 
  70.         var code=document.querySelector('#code').value; 
  71.         IdentityCodeValid(code); 
  72.         document.querySelector('#home span').innerHTML=home
  73.         document.querySelector('#birthday span').innerHTML=birthday
  74.         document.querySelector('#sex span').innerHTML=sex
  75.     } 
  76. </script> 

 

热门文章推荐

请稍候...

保利威视云平台-轻松实现点播直播视频应用

酷播云数据统计分析跨平台播放器