詳解正則表達(dá)式實現(xiàn)二代身份證號碼驗證
最近項目需要對身份證進(jìn)行比較合理的篩選,并不想用到第三方接口,所以寫了個方法:
包括支持身份證號合法性驗證, 支持18位身份證號,支持地址編碼、出生日期、校驗位驗證. 基本上這樣就可以了.
IdCodeValid:function(code){
//身份證號合法性驗證
//支持15位和18位身份證號
//支持地址編碼、出生日期、校驗位驗證
var city={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:"國外 "};
var row={
'pass':true,
'msg':'驗證成功'
};
if(!code || !/^\d{6}(18|19|20)?\d{2}(0[1-9]|1[012])(0[1-9]|[12]\d|3[01])\d{3}(\d|[xX])$/.test(code)){
row={
'pass':false,
'msg':'身份證號格式錯誤'
};
}else if(!city[code.substr(0,2)]){
row={
'pass':false,
'msg':'身份證號地址編碼錯誤'
};
}else{
//18位身份證需要驗證最后一位校驗位
if(code.length == 18){
code = code.split('');
//∑(ai×Wi)(mod 11)
//加權(quán)因子
var factor = [ 7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2 ];
//校驗位
var parity = [ 1, 0, 'X', 9, 8, 7, 6, 5, 4, 3, 2 ];
var sum = 0;
var ai = 0;
var wi = 0;
for (var i = 0; i < 17; i++)
{
ai = code[i];
wi = factor[i];
sum += ai * wi;
}
if(parity[sum % 11] != code[17].toUpperCase()){
row={
'pass':false,
'msg':'身份證號校驗位錯誤'
};
}
}
}
return row;
}
IdCodeValid('xxx');
正則表達(dá)式:
出生日期1800-2099 (18|19|20)?\d{2}(0[1-9]|1[012])(0[1-9]|[12]\d|3[01])
身份證正則表達(dá)式 /^\d{6}(18|19|20)?\d{2}(0[1-9]|1[012])(0[1-9]|[12]\d|3[01])\d{3}(\d|[xX])$/
位校驗規(guī)則 6位地址編碼+8位出生日期+3位順序號+1位校驗位
總結(jié)
以上所述是小編給大家介紹的正則表達(dá)式實現(xiàn)二代身份證號碼驗證,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
相關(guān)文章
JavaScript正則表達(dá)式校驗非零的負(fù)整數(shù)實例
本文分享了JavaScript正則表達(dá)式(^-[1-9]\d*$)校驗非零的負(fù)整數(shù)實例代碼,代碼簡單易懂,需要的朋友可以看下2016-12-12
正則表達(dá)式其實就是一個特殊的字符串,如果需要對字符串的內(nèi)容進(jìn)行分析匹配,正則表達(dá)式是一個不錯的選擇。簡單的用String也能實現(xiàn)該過程,但是那會相當(dāng)?shù)姆爆?/div> 2012-10-10
正則表達(dá)式口訣 正則表達(dá)式學(xué)習(xí)工具
正則表達(dá)式口訣 + 常用的正則表達(dá)式 + 正則表達(dá)式學(xué)習(xí)工具+正則處理工具 正則是每個程序員繞不開的堡壘,只有把它攻下來。我覺得正則之所以難,第一難是需要記憶,第二難是要求具備抽象邏輯思維。2008-08-08最新評論

