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


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

    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>  
  • 相关阅读:
    Java正则表达式, 提取双引号中间的部分
    如何快速找到未知长度单链表的中心点的值
    西格玛
    对数
    jquery显示隐藏toggle
    JavaScript:改变li前缀图片和样式
    jquery点击改变图片src源码并toggle
    jquery点击改变class并toggle
    linux下合并两个文件夹
    编译安装httpd
  • 原文地址:https://www.cnblogs.com/dwnblogs/p/2975788.html
Copyright © 2020-2023  润新知