DIV CSS 佈局教程網

 DIV+CSS佈局教程網 >> 網頁腳本 >> JavaScript入門知識 >> 關於JavaScript >> 超精准的javascript驗證身份證號的具體實現方法
超精准的javascript驗證身份證號的具體實現方法
編輯:關於JavaScript     

編寫程序前先來了解下身份證號的構成:

身份證號分為兩種,舊的為15位,新的為18位。

身份證15位編碼規則:dddddd yymmdd xx p   

其中 dddddd:地區碼    yymmdd: 出生年月日    xx: 順序類編碼,無法確定    p: 性別,奇數為男,偶數為女;

身份證18位編碼規則:dddddd yyyymmdd xxx y   

其中 dddddd:地區碼    yyyymmdd: 出生年月日     xxx:順序類編碼,無法確定,奇數為男,偶數為女    y: 校驗碼,該位數值可通過前17位計算獲得,計算的公式見程序,一些需要用到的常數

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);  //進行15位身份證的驗證 
 } else if (idCard.length == 18) { 
  var a_idCard = idCard.split("");    // 得到身份證數組 
  if(isValidityBrithBy18IdCard(idCard)&&isTrueValidateCodeBy18IdCard(a_idCard)){ //進行18位身份證的基本驗證和第18位的驗證
   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; 
 } 
} 
/** 
 * 驗證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, ""); 
} 

 根據身份證號對其進行性別的判定

/** 
 * 通過身份證判斷是男是女 
 * @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; 
 } 
} 

以上就是javascript驗證身份證號的具體實現方法,並且根據身份證能驗證性別,是不是很神奇,歡迎大家學習借鑒。

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