1. 程式人生 > >正則表示式擷取身份證號碼加密的方法

正則表示式擷取身份證號碼加密的方法

下面一段簡單的程式碼給大家介紹正則表示式擷取身份證號碼加密的方法,具體程式碼如下所示:

直接上程式碼:

1 2 3 4 var idCard = '420119188404098978X' ; // 保留前四位和後四位,中間用*號加密
idCard = idCard.replace(/(\d{4})\d*([0-9a-zA-Z]{4})/, "$1******$2" ); // 結果:4201******978X

PS:下面介紹比較規範的身份證號驗證正則表示式

一些要求使用者資訊比較嚴格的地方比如使用者註冊、登入的時候都需要驗證使用者的身份證是否合法,而通過這些驗證能大大的過濾掉很多水客,給你的系統帶來非常精準的使用者資訊。

  很多時候我們都是通過一組正則表示式來判斷使用者輸入的身份證是否合法,那在用正則表示式判斷之前,你對身份證號的組成有多少了解呢?下面來說說一個身份證號裡面包含了多少的資訊:

  1、號碼的結構

    公民身份號碼是特徵組合碼,由十七位數字本體碼和一位校驗碼組成。排列順序從左至右依次為:六位數字地址碼,八位數字出生日期碼,三位數字順序碼和一位數字校驗碼。

  2、地址碼(前六位數)

    表示編碼物件常住戶口所在縣(市、旗、區)的行政區劃程式碼,按gb/T2260的規定執行。

  3、出生日期碼(第七位至十四位)

    表示編碼物件出生的年、月、日,按gb/T7408的規定執行,年、月、日程式碼之間不用分隔符。

  4、順序碼(第十五位至十七位)

    表示在同一地址碼所標識的區域範圍內,對同年、同月、同日出生的人編定的順序號,順序碼的奇數分配給男性,偶數分配給女性。

  5、校驗碼(第十八位數)

    作為尾號的校驗碼,是由號碼編制單位按統一的公式計算出來的,如果某人的尾號是0-9,都不會出現X,但如果尾號是10,那麼就得用X來代替,因為如果用10做尾號,那麼 此人的身份證就變成了19位。X是羅馬數字的10,用X來代替10,可以保證公民的身份證符合國家標準。

  在知道身份證號結構組成各部分的意思後,我們開始進入主題:

  1、定義一個全國地區的物件

1 var aCity={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: "國外" }

  2、正則表示式判斷

1 2 3 4 5 6 7 8 9 10 11 12 13 14 function isCardID(sId){    var iSum=0 ;    var info= "" ;    if (!/^\d{17}(\d|x)$ /i . test (sId)) return "你輸入的身份證長度或格式錯誤" ;    sId=sId.replace( /x $ /i , "a" );    if (aCity[parseInt(sId.substr(0,2))]==null) return "你的身份證地區非法" ;    sBirthday=sId.substr(6,4)+ "-" +Number(sId.substr(10,2))+ "-" +Number(sId.substr(12,2));    var d=new Date(sBirthday.replace( /-/g , "/" )) ;    if (sBirthday!=(d.getFullYear()+ "-" + (d.getMonth()+1) + "-" + d.getDate())) return "身份證上的出生日期非法" ;    for (var i = 17;i>=0;i --) iSum += (Math.pow(2,i) % 11) * parseInt(sId.charAt(17 - i),11) ;    if (iSum%11!=1) return "你輸入的身份證號非法" ;    //aCity [parseInt(sId.substr(0,2))]+ "," +sBirthday+ "," +(sId.substr(16,1)%2? "男" : "女" ); // 此次還可以判斷出輸入的身份證號的人性別    return true ; }