DIV CSS 佈局教程網

 DIV+CSS佈局教程網 >> 網頁腳本 >> JavaScript入門知識 >> JavaScript綜合知識 >> js實現身份證號碼驗證的簡單實例
js實現身份證號碼驗證的簡單實例
編輯:JavaScript綜合知識     

 本篇文章主要是對js實現身份證號碼驗證的簡單實例進行了介紹,需要的朋友可以過來參考下,希望對大家有所幫助

以下是根據身份證號碼編碼規則,使用JS對其進行有效性驗證代碼   IdCard-Validate.js代碼如下:     代碼如下: /**  * 身份證15位編碼規則:dddddd yymmdd xx p   * dddddd:地區碼   * yymmdd: 出生年月日   * xx: 順序類編碼,無法確定   * p: 性別,奇數為男,偶數為女  * <p />  * 身份證18位編碼規則:dddddd yyyymmdd xxx y   * dddddd:地區碼   * yyyymmdd: 出生年月日   * xxx:順序類編碼,無法確定,奇數為男,偶數為女   * y: 校驗碼,該位數值可通過前17位計算獲得  * <p />  * 18位號碼加權因子為(從右到左) Wi = [ 7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2,1 ]  * 驗證位 Y = [ 1, 0, 10, 9, 8, 7, 6, 5, 4, 3, 2 ]   * 校驗位計算公式:Y_P = mod( ∑(Ai×Wi),11 )   * i為身份證號碼從右往左數的 2...18 位; Y_P為腳丫校驗碼所在校驗碼數組位置  *   */   var Wi = [ 7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2, 1 ];// 加權因子 var ValideCode = [ 1, 0, 10, 9, 8, 7, 6, 5, 4, 3, 2 ];// 身份證驗證位值.10代表X function IdCardValidate(idCard) {  idCard = trim(idCard.replace(/ /g, ""));  if (idCard.length == 15) {   return isValidityBrithBy15IdCard(idCard);  } else if (idCard.length == 18) {   var a_idCard = idCard.split("");// 得到身份證數組   if(isValidityBrithBy18IdCard(idCard)&&isTrueValidateCodeBy18IdCard(a_idCard)){    return true;   }else {    return false;   }  } else {   return false;  } } /**  * 判斷身份證號碼為18位時最後的驗證位是否正確  * @param a_idCard 身份證號碼數組  * @return  */ function isTrueValidateCodeBy18IdCard(a_idCard) {  var sum = 0; // 聲明加權求和變量  if (a_idCard[17].toLowerCase() == 'x') {   a_idCard[17] = 10;// 將最後位為x的驗證碼替換為10方便後續操作  }  for ( var i = 0; i < 17; i++) {   sum += Wi[i] * a_idCard[i];// 加權求和  }  valCodePosition = sum % 11;// 得到驗證碼所位置  if (a_idCard[17] == ValideCode[valCodePosition]) {   return true;  } else {   return false;  } } /**  * 通過身份證判斷是男是女  * @param idCard 15/18位身份證號碼   * @return 'female'-女、'male'-男  */ function maleOrFemalByIdCard(idCard){  idCard = trim(idCard.replace(/ /g, ""));// 對身份證號碼做處理。包括字符間有空格。  if(idCard.length==15){   if(idCard.substring(14,15)%2==0){    return 'female';   }else{    return 'male';   }  }else if(idCard.length ==18){   if(idCard.substring(14,17)%2==0){    return 'female';   }else{    return 'male';   }  }else{   return null;  } // 可對傳入字符直接當作數組來處理 // if(idCard.length==15){ // alert(idCard[13]); // if(idCard[13]%2==0){ // return 'female'; // }else{ // return 'male'; // } // }else if(idCard.length==18){ // alert(idCard[16]); // if(idCard[16]%2==0){ // return 'female'; // }else{ // return 'male'; // } // }else{ // return null; // } }  /**   * 驗證18位數身份證號碼中的生日是否是有效生日   * @param idCard 18位書身份證字符串   * @return   */ function isValidityBrithBy18IdCard(idCard18){  var year =  idCard18.substring(6,10);  var month = idCard18.substring(10,12);  var day = idCard18.substring(12,14);  var temp_date = new Date(year,parseFloat(month)-1,parseFloat(day));  // 這裡用getFullYear()獲取年份,避免千年蟲問題  if(temp_date.getFullYear()!=parseFloat(year)        ||temp_date.getMonth()!=parseFloat(month)-1        ||temp_date.getDate()!=parseFloat(day)){         return false;  }else{   return true;  } }   /**    * 驗證15位數身份證號碼中的生日是否是有效生日    * @param idCard15 15位書身份證字符串    * @return    */   function isValidityBrithBy15IdCard(idCard15){    var year =  idCard15.substring(6,8);    var month = idCard15.substring(8,10);    var day = idCard15.substring(10,12);    var temp_date = new Date(year,parseFloat(month)-1,parseFloat(day));    // 對於老身份證中的你年齡則不需考慮千年蟲問題而使用getYear()方法    if(temp_date.getYear()!=parseFloat(year)         ||temp_date.getMonth()!=parseFloat(month)-1         ||temp_date.getDate()!=parseFloat(day)){          return false;   }else{    return true;   }   } //去掉字符串頭尾空格 function trim(str) {  return str.replace(/(^/s*)|(/s*$)/g, ""); }     對於上述代碼中,關於性別的判斷在實際使用中,可加入首先判斷身份證是否有效。在本代碼示例中並未進行該種判斷,有點雞肋的感覺,可在實際使用中根據情況進行豐滿。  
XML學習教程| jQuery入門知識| AJAX入門| Dreamweaver教程| Fireworks入門知識| SEO技巧| SEO優化集錦|
Copyright © DIV+CSS佈局教程網 All Rights Reserved