欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

基于javascript簡單實現(xiàn)對身份證校驗

 更新時間:2021年01月25日 12:03:19   作者:留——痕  
這篇文章主要介紹了基于javascript簡單實現(xiàn)對身份證校驗的相關(guān)資料,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下

本文實例介紹了javascript簡單實現(xiàn)對身份證的校驗的關(guān)鍵性代碼,分享給大家供大家參考,具體內(nèi)容如下

var vcity={ 11:"北京",12:"天津",13:"河北",14:"山西",15:"內(nèi)蒙古", 
21:"遼寧",22:"吉林",23:"黑龍江",31:"上海",32:"江蘇", 
33:"浙江",34:"安徽",35:"福建",36:"江西",37:"山東",41:"河南", 
42:"湖北",43:"湖南",44:"廣東",45:"廣西",46:"海南",50:"重慶", 
51:"四川",52:"貴州",53:"云南",54:"西藏",61:"陜西",62:"甘肅", 
63:"青海",64:"寧夏",65:"新疆",71:"臺灣",81:"香港",82:"澳門",91:"國外" 
}; 

checkCard = function(card) 
{ 

//是否為空 
if(card === '') 
{ 

return "請輸入身份證號,身份證號不能為空"; 
} 
//校驗長度,類型 
if(isCardNo(card) === false) 
{ 

return "您輸入的身份證號碼不正確,請重新輸入"; 
} 
//檢查省份 
if(checkProvince(card) === false) 
{ 
return "您輸入的身份證號碼不正確,請重新輸入"; 
} 
//校驗生日 
if(checkBirthday(card) === false) 
{ 
return "您輸入的身份證號碼生日不正確,請重新輸入"; 
} 
//檢驗位的檢測 
if(checkParity(card) === false) 
{ 
return "您的身份證校驗位不正確,請重新輸入"; 
} 

return "ok"; 
}; 


//檢查號碼是否符合規(guī)范,包括長度,類型 
isCardNo = function(card) 
{ 
//身份證號碼為15位或者18位,15位時全為數(shù)字,18位前17位為數(shù)字,最后一位是校驗位,可能為數(shù)字或字符X 
var reg = /(^\d{15}$)|(^\d{17}(\d|X)$)/; 
if(reg.test(card) === false) 
{ 
return false; 
} 

return true; 
}; 

//取身份證前兩位,校驗省份 
checkProvince = function(card) 
{ 
var province = card.substr(0,2); 
if(vcity[province] == undefined) 
{ 
return false; 
} 
return true; 
}; 

//檢查生日是否正確 
checkBirthday = function(card) 
{ 
var len = card.length; 
//身份證15位時,次序為省(3位)市(3位)年(2位)月(2位)日(2位)校驗位(3位),皆為數(shù)字 
if(len == '15') 
{ 
var re_fifteen = /^(\d{6})(\d{2})(\d{2})(\d{2})(\d{3})$/; 
var arr_data = card.match(re_fifteen); 
var year = arr_data[2]; 
var month = arr_data[3]; 
var day = arr_data[4]; 
var birthday = new Date('19'+year+'/'+month+'/'+day); 
return verifyBirthday('19'+year,month,day,birthday); 
} 
//身份證18位時,次序為?。?位)市(3位)年(4位)月(2位)日(2位)校驗位(4位),校驗位末尾可能為X 
if(len == '18') 
{ 
var re_eighteen = /^(\d{6})(\d{4})(\d{2})(\d{2})(\d{3})([0-9]|X)$/; 
var arr_data = card.match(re_eighteen); 
var year = arr_data[2]; 
var month = arr_data[3]; 
var day = arr_data[4]; 
var birthday = new Date(year+'/'+month+'/'+day); 
return verifyBirthday(year,month,day,birthday); 
} 
return false; 
}; 

//校驗日期 
verifyBirthday = function(year,month,day,birthday) 
{ 
var now = new Date(); 
var now_year = now.getFullYear(); 
//年月日是否合理 
if(birthday.getFullYear() == year && (birthday.getMonth() + 1) == month && birthday.getDate() == day) 
{ 
//判斷年份的范圍(3歲到100歲之間) 
var time = now_year - year; 
if(time >= 3 && time <= 100) 
{ 
return true; 
} 
return false; 
} 
return false; 
}; 

//校驗位的檢測 
checkParity = function(card) 
{ 
//15位轉(zhuǎn)18位 
card = changeFivteenToEighteen(card); 
var len = card.length; 
if(len == '18') 
{ 
var arrInt = new Array(7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2); 
var arrCh = new Array('1', '0', 'X', '9', '8', '7', '6', '5', '4', '3', '2'); 
var cardTemp = 0, i, valnum; 
for(i = 0; i < 17; i ++) 
{ 
cardTemp += card.substr(i, 1) * arrInt[i]; 
} 
valnum = arrCh[cardTemp % 11]; 
if (valnum == card.substr(17, 1)) 
{ 
return true; 
} 
return false; 
} 
return false; 
}; 

//15位轉(zhuǎn)18位身份證號 
changeFivteenToEighteen = function(card) 
{ 
if(card.length == '15') 
{ 
var arrInt = new Array(7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2); 
var arrCh = new Array('1', '0', 'X', '9', '8', '7', '6', '5', '4', '3', '2'); 
var cardTemp = 0, i; 
card = card.substr(0, 6) + '19' + card.substr(6, card.length - 6); 
for(i = 0; i < 17; i ++) 
{ 
cardTemp += card.substr(i, 1) * arrInt[i]; 
} 
card += arrCh[cardTemp % 11]; 
return card; 
} 
return card; 
};

以上就是本文的全部內(nèi)容,希望對大家實現(xiàn)javascript身份證校驗有所幫助。

相關(guān)文章

  • 使用JavaScript switch case 另類寫法

    使用JavaScript switch case 另類寫法

    在JavaScript里,函數(shù)(todoA、todoB、todoC)就是對象,“()”的作用就是就是執(zhí)行函數(shù)對象,二者簡單地組合一下就能夠讓代碼清晰簡潔很多了,何樂不為呢?
    2010-03-03
  • 如何用js將blob為pcm格式轉(zhuǎn)換為MP3格式

    如何用js將blob為pcm格式轉(zhuǎn)換為MP3格式

    要將PCM文件轉(zhuǎn)換為MP3文件,您可以使用Js實現(xiàn),這篇文章主要給大家介紹了關(guān)于如何用js將blob為pcm格式轉(zhuǎn)換為MP3格式的相關(guān)資料,需要的朋友可以參考下
    2023-11-11
  • 實現(xiàn)無刷新聯(lián)動例子匯總

    實現(xiàn)無刷新聯(lián)動例子匯總

    最近在用asp.net做項目的時候,遇到需要實現(xiàn)無刷新聯(lián)動的需求,度娘了一下,這里匯總一下幾個比較實用的例子,有需要的小伙伴可以參考下。
    2015-05-05
  • js定時器+簡單的動畫效果實例

    js定時器+簡單的動畫效果實例

    下面小編就為大家?guī)硪黄猨s定時器+簡單的動畫效果實例。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-11-11
  • 基于JavaScript實現(xiàn)在線網(wǎng)頁煙花效果

    基于JavaScript實現(xiàn)在線網(wǎng)頁煙花效果

    這篇文章主要為大家詳細介紹了如何利用JavaScript實現(xiàn)簡單的在線網(wǎng)頁煙花效果,文中的示例代碼講解詳細,感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下
    2023-02-02
  • JavaScript常用8種數(shù)組去重代碼實例

    JavaScript常用8種數(shù)組去重代碼實例

    這篇文章主要介紹了JavaScript常用8種數(shù)組去重代碼實例,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2020-09-09
  • layui 數(shù)據(jù)表格+分頁+搜索+checkbox+緩存選中項數(shù)據(jù)的方法

    layui 數(shù)據(jù)表格+分頁+搜索+checkbox+緩存選中項數(shù)據(jù)的方法

    今天小編就為大家分享一篇layui 數(shù)據(jù)表格+分頁+搜索+checkbox+緩存選中項數(shù)據(jù)的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-09-09
  • mint-ui的search組件在鍵盤顯示搜索按鈕的實現(xiàn)方法

    mint-ui的search組件在鍵盤顯示搜索按鈕的實現(xiàn)方法

    這篇文章主要介紹了mint-ui的search組件在鍵盤顯示搜索按鈕的實現(xiàn)方法,需要的朋友可以參考下
    2017-10-10
  • 小程序云開發(fā)初探(小結(jié))

    小程序云開發(fā)初探(小結(jié))

    云開發(fā)是微信平臺新開放的功能,為開發(fā)者提供集成了服務(wù)器,數(shù)據(jù)庫和資源存儲的云服務(wù)。這篇文章主要介紹了小程序云開發(fā)初探(小結(jié)),感興趣的小伙伴們可以參考一下
    2018-10-10
  • js模擬微博發(fā)布消息

    js模擬微博發(fā)布消息

    本文主要介紹了js模擬微博發(fā)布消息的實例,具有很好的參考價值,下面跟著小編一起來看下吧
    2017-02-02

最新評論