身份证号码的规则及验证原理

身份证号码的规则及验证原理  

2009-12-01 10:52:24|  分类: javascript编程|字号 订阅

 
 
【身份证号码的规则】
1、15位身份证号码组成:
ddddddyymmddxxs共15位,其中:
dddddd为6位的地方代码,根据这6位可以获得该身份证号所在地。
yy为2位的年份代码,是身份证持有人的出身年份。
mm为2位的月份代码,是身份证持有人的出身月份。
dd为2位的日期代码,是身份证持有人的出身日。
这6位在一起组成了身份证持有人的出生日期。
xx为2位的顺序码,这个是随机数。
s为1位的性别代码,奇数代表男性,偶数代表女性。
 
2、18位身份证号码组成:
ddddddyyyymmddxxsp共18位,其中:
其他部分都和15位的相同。年份代码由原来的2位升级到4位。最后一位为校验位。
校验规则是:
(1)十七位数字本体码加权求和公式 
S = Sum(Ai * Wi), i = 0, ... , 16 ,先对前17位数字的权求和 
Ai:表示第i位置上的身份证号码数字值 
Wi:表示第i位置上的加权因子 
Wi: 7 9 10 5 8 4 2 1 6 3 7 9 10 5 8 4 2 
(2)计算模 
Y = mod(S, 11) 
(3)通过模得到对应的校验码 
Y: 0 1 2 3 4 5 6 7 8 9 10 
校验码: 1 0 X 9 8 7 6 5 4 3 2

也就是说,如果得到余数为1则最后的校验位p应该为对应的0.如果校验位不是,则该身份证号码不正确。以下为js版本的校验实例。

  1. <script language="javascript">   
  2.      <!--   
  3.     var powers=newArray("7","9","10","5","8","4","2","1","6","3","7","9","10","5","8","4","2");   
  4.     var parityBit=new Array("1","0","X","9","8","7","6","5","4","3","2");   
  5.     var sex="male";   
  6.     //校验身份证号码的主调用   
  7.   
  8.     function validId(obj){   
  9.         var _id=obj.value;   
  10.         if(_id=="")return;   
  11.         var _valid=false;   
  12.         if(_id.length==15){   
  13.              _valid=validId15(_id);   
  14.          }else if(_id.length==18){   
  15.              _valid=validId18(_id);   
  16.          }   
  17.         if(!_valid){   
  18.              alert("身份证号码有误,请检查!");   
  19.              obj.focus();   
  20.             return;   
  21.          }   
  22.         //设置性别   
  23.   
  24.         var sexSel=document.getElementById("sex");   
  25.         var options=sexSel.options;   
  26.         for(var i=0;i<options.length;i++){   
  27.             if(options[i].value==sex){   
  28.                  options[i].selected=true;   
  29.                 break;   
  30.              }   
  31.          }   
  32.      }       
  33.     //校验18位的身份证号码   
  34.   
  35.     function validId18(_id){   
  36.          _id=_id+"";   
  37.         var _num=_id.substr(0,17);   
  38.         var _parityBit=_id.substr(17);   
  39.         var _power=0;   
  40.         for(var i=0;i< 17;i++){   
  41.             //校验每一位的合法性   
  42.   
  43.             if(_num.charAt(i)<'0'||_num.charAt(i)>'9'){   
  44.                 return false;   
  45.                 break;   
  46.              }else{   
  47.                 //加权   
  48.   
  49.                  _power+=parseInt(_num.charAt(i))*parseInt(powers[i]);   
  50.                 //设置性别   
  51.   
  52.                 if(i==16&&parseInt(_num.charAt(i))%2==0){   
  53.                      sex="female";   
  54.                  }else{   
  55.                      sex="male";   
  56.                  }   
  57.              }   
  58.          }   
  59.         //取模   
  60.   
  61.         var mod=parseInt(_power)%11;   
  62.         if(parityBit[mod]==_parityBit){   
  63.             return true;   
  64.          }   
  65.         return false;   
  66.      }   
  67.     //校验15位的身份证号码   
  68.   
  69.     function validId15(_id){   
  70.          _id=_id+"";   
  71.         for(var i=0;i<_id.length;i++){   
  72.             //校验每一位的合法性   
  73.   
  74.             if(_id.charAt(i)<'0'||_id.charAt(i)>'9'){   
  75.                 return false;   
  76.                 break;   
  77.              }   
  78.          }   
  79.         var year=_id.substr(6,2);   
  80.         var month=_id.substr(8,2);   
  81.         var day=_id.substr(10,2);   
  82.         var sexBit=_id.substr(14);   
  83.         //校验年份位   
  84.   
  85.         if(year<'01'||year >'90')return false;   
  86.         //校验月份   
  87.   
  88.         if(month<'01'||month >'12')return false;   
  89.         //校验日   
  90.   
  91.         if(day<'01'||day >'31')return false;   
  92.         //设置性别   
  93.   
  94.         if(sexBit%2==0){   
  95.              sex="female";   
  96.          }else{   
  97.              sex="male";   
  98.          }   
  99.         return true;   
  100.      }   
  101.     //-->   
  102.   
  103. </script>   
  104. <input type="text" onblur="validId(this)" maxlength=18 size=18>   
  105. <select id="sex">   
  106.      <option value="male">男</option>   
  107.      <option value="female">女</option>  

posted on 2013-03-22 16:10  百年孤寂dwn  阅读(11184)  评论(0编辑  收藏  举报

导航