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

[JS]身份证位数查询身份证验证查询与匹配

时间:2015-01-21 17:10酷播
[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.             //CuPlayer.com提示:生日 
  60.             birthday = code.substring(6,10)+'年'+code.substring(10,12)+'月'+code.substring(12,14)+'日'; 
  61.             //CuPlayer.com提示:性别 
  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> 

 

热门文章推荐

请稍候...