DIV CSS 佈局教程網

 DIV+CSS佈局教程網 >> 網頁腳本 >> JavaScript入門知識 >> 關於JavaScript >> Javascript代碼:校驗身份證號程序
Javascript代碼:校驗身份證號程序
編輯:關於JavaScript     

網頁制作poluoluo文章簡介:也就是說,如果得到余數為1則最後的校驗位p應該為對應的0.如果校驗位不是,則該身份證號碼不正確。以下為js版本的校驗實例。

【身份證號碼的規則】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版本的校驗實例。


Js代碼
<script language="javascript">   
     <!--   
    var powers=new Array("7","9","10","5","8","4","2","1","6","3","7","9","10","5","8","4","2");   
    var parityBit=new Array("1","0","X","9","8","7","6","5","4","3","2");   
    var sex="male";   
    //校驗身份證號碼的主調用   
  
    function validId(obj){   
        var _id=obj.value;   
        if(_id=="")return;   
        var _valid=false;   
        if(_id.length==15){   
             _valid=validId15(_id);   
         }else if(_id.length==18){   
             _valid=validId18(_id);   
         }   
        if(!_valid){   
             alert("身份證號碼有誤,請檢查!");   
             obj.focus();   
            return;   
         }   
        //設置性別   
  
        var sexSel=document.getElementById("sex");   
        var options=sexSel.options;   
        for(var i=0;i<options.length;i++){   
            if(options[i].value==sex){   
                 options[i].selected=true;   
                break;   
             }   
         }   
     }       
    //校驗18位的身份證號碼   
  
    function validId18(_id){   
         _id=_id+"";   
        var _num=_id.substr(0,17);   
        var _parityBit=_id.substr(17);   
        var _power=0;   
        for(var i=0;i< 17;i++){   
            //校驗每一位的合法性   
  
            if(_num.charAt(i)<'0'||_num.charAt(i)>'9'){   
                return false;   
                break;   
             }else{   
                //加權   
  
                 _power+=parseInt(_num.charAt(i))*parseInt(powers[i]);   
                //設置性別   
  
                if(i==16&&parseInt(_num.charAt(i))%2==0){   
                     sex="female";   
                 }else{   
                     sex="male";   
                 }   
             }   
         }   
        //取模   
  
        var mod=parseInt(_power)%11;   
        if(parityBit[mod]==_parityBit){   
            return true;   
         }   
        return false;   
     }   
    //校驗15位的身份證號碼   
  
    function validId15(_id){   
         _id=_id+"";   
        for(var i=0;i<_id.length;i++){   
            //校驗每一位的合法性   
  
            if(_id.charAt(i)<'0'||_id.charAt(i)>'9'){   
                return false;   
                break;   
             }   
         }   
        var year=_id.substr(6,2);   
        var month=_id.substr(8,2);   
        var day=_id.substr(10,2);   
        var sexBit=_id.substr(14);   
        //校驗年份位   
  
        if(year<'01'||year >'90')return false;   
        //校驗月份   
  
        if(month<'01'||month >'12')return false;   
        //校驗日   
  
        if(day<'01'||day >'31')return false;   
        //設置性別   
  
        if(sexBit%2==0){   
             sex="female";   
         }else{   
             sex="male";   
         }   
        return true;   
     }   
    //-->   
  
</script>   
<input type="text" onblur="validId(this)" maxlength=18 size=18>   
<select id="sex">   
     <option value="male">男</option>   
     <option value="female">女</option>

XML學習教程| jQuery入門知識| AJAX入門| Dreamweaver教程| Fireworks入門知識| SEO技巧| SEO優化集錦|
Copyright © DIV+CSS佈局教程網 All Rights Reserved