精確驗證身份證號碼合法性程式碼例項
當前有很多關於身份證合法性驗證的程式碼,但是很多都不夠精準,僅僅是對於號碼的位數或者其他方面進行簡單驗證。
本章節分享一段例項程式碼,它能夠比較精準的驗證身份證合法性效果。
程式碼例項如下:
[HTML] 純文字檢視 複製程式碼<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <meta name="author" content="http://www.softwhy.com/" /> <title>螞蟻部落</title> <script src="http://libs.baidu.com/jquery/1.9.0/jquery.js"></script> <script type="text/javascript"> function nunber(allowancePersonValue){ if(allowancePersonValue=="身份證號"){ $("#span_username").show(); $("#span_username").html("身份證號不能為空"); return false; } //校驗長度,型別 else if(isCardNo(allowancePersonValue) === false){ $("#span_username").show(); $("#span_username").html("您輸入的身份證號碼不正確,請重新輸入"); return false; } //檢查省份 else if(checkProvince(allowancePersonValue) === false){ $("#span_username").show(); $("#span_username").html("您輸入的身份證號碼不正確,請重新輸入"); return false; } //校驗生日 else if(checkBirthday(allowancePersonValue) === false){ $("#span_username").show(); $("#span_username").html("您輸入的身份證號碼生日不正確,請重新輸入"); return false; } //檢驗位的檢測 else if(checkParity(allowancePersonValue) === false){ $("#span_username").show(); $("#span_username").html("您的身份證校驗位不正確,請重新輸入"); return false; } else{ $("#span_username").hide(); return true; } } //身份證省的編碼 var vcity={ 11:"北京",12:"天津",13:"河北",14:"山西",15:"內蒙古", 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:"國外" }; //檢查號碼是否符合規範,包括長度,型別 function isCardNo(card){ //身份證號碼為15位或者18位,15位時全為數字,18位前17位為數字,最後一位是校驗位,可能為數字或字元X var reg = /(^\d{15}$)|(^\d{17}(\d|X)$)/; if(reg.test(card) === false){ //alert("demo"); return false; } return true; } //取身份證前兩位,校驗省份 function checkProvince(card){ var province = card.substr(0,2); if(vcity[province] == undefined){ return false; } return true; } //檢查生日是否正確 function checkBirthday(card){ var len = card.length; //身份證15位時,次序為省(3位)市(3位)年(2位)月(2位)日(2位)校驗位(3位),皆為數字 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位)市(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; } //校驗日期 function verifyBirthday(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; } //校驗位的檢測 function checkParity(card){ //15位轉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位轉18位身份證號 function changeFivteenToEighteen(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; } $(document).ready(function(){ $("#username").focus(function(){ if(this.value=='身份證號'){ this.value=''; } }) $("#username").blur(function(){ if(this.value==''){ this.value='身份證號'; } nunber(this.value); }) }); </script> </head> <body> <input type="text" class="reg_txt" value="身份證號" titles="請輸入您的身份證號!" name="userid" id="username"><br> <span class="c_red" id="span_username"></span> </body> </html>
相關文章
- 精確驗證身份證號碼程式碼
- 精準實現身份證號碼格式校驗程式碼例項
- javascript實現的身份證號碼合法性驗證程式碼JavaScript
- 驗證ip地址合法性程式碼例項
- 驗證子網掩碼合法性程式碼例項
- js實現的身份證合法性驗證程式碼JS
- PHP 驗證身份證號碼PHP
- PHP 身份證精確匹配驗證PHP
- php與js方式驗證手機號碼和郵件地址的合法性,js驗證身份證號碼PHPJS
- javascript實現的身份證號碼驗證程式碼JavaScript
- excel身份證號提取年齡公式 身份證號碼提取精確年齡的公式Excel公式
- 身份證號碼驗證系統
- 身份證號碼之js驗證JS
- 驗證手機號碼格式的程式碼例項
- 驗證手機號碼程式碼簡單程式碼例項
- JS校驗身份證號的合法性JS
- 手機號碼和電話號碼合法性驗證程式碼
- 身份證號碼驗證演算法演算法
- js實現身份證號碼驗證JS
- 根據身份證號碼獲取性別資訊程式碼例項
- javascript身份證號碼校驗JavaScript
- JS驗證身份證的合法性JS
- 表單驗證手機號碼格式例項程式碼
- jquery 驗證碼效果程式碼例項jQuery
- jQuery加法驗證碼效果程式碼例項jQuery
- JavaScript 表單驗證程式碼例項JavaScript
- 郵箱格式驗證程式碼例項
- JS驗證18位身份證號的正確性JS
- javascript實現的驗證碼程式碼例項JavaScript
- C++身份核驗介面程式碼、身份證OCR、身份證實名認證APIC++API
- Ext實現的身份證格式驗證程式碼
- 中國身份證號驗證庫
- C++身份證號驗證C++
- C#驗證身份證號C#
- javascript驗證郵箱格式程式碼例項JavaScript
- canvas實現的驗證碼效果程式碼例項Canvas
- swift 郵箱、密碼、手機號、身份證驗證正則Swift密碼
- 身份證號碼校驗位的計算方式