15位身份證補全為18位身份證演算法

發表於2017-06-25

最近在參與一個銀行專案-某銀行安防系統-反洗錢需求的開發,銀行專案的離不開身份證號碼,身份證號碼作為我國公民的唯一標識,有這非同尋常的意義,由於業務的要求15位的身份證號碼無法命中,所以需要補全為18位,一開始自己想著加個年份的前兩位,後面再加個X不就行了嘛,後來程式碼寫不下去了,上網查了資料,才知道自己想的是多麼天真,還是比較複雜的,折騰了一下午終於有了眉目。

一、15位身份證和18位身份證號碼結構介紹

要進行身份證號碼的驗證,首先需要了解我國身份證號碼的編碼規則。我國身份證號碼多由若干位數字或者數字與字母混合組成。早期身份證由15位數字構成,這主要是在1980年以前發放的身份證,後來考慮到千年蟲問題,因為15位的身份證號碼只能為1900年1月1日到1999年12月31日出生的人編號,所以又增加了18位身份證號碼編號規則。

1     2     3     4     5     6     7     8     9     10   11   12   13   14   15

A     A     A     A     A     A     Y     Y     M    M    D     D     N    N    S

前六位AAAAAA是身份證編碼物件的所在地(出生地)的編碼,該號碼可由國家統計局公佈的相關標準中得到。YY表示出生年的後兩位,MM和DD表示出生月和日,不足兩位的高位補0,NNS為順序號,無法確定。S為性別識別碼,男性為奇數,女性為偶數。瞭解了這些,再來寫程式碼就變得容易多了。

二、演算法實現

瞭解了身份證號碼的規則後,我們就可以推斷出,身份證的15位轉化位需要兩步。首先把15位身份證號補全為17位,然後再補全最後一位。但是最後一位是數字還是字母X?這裡又出現了問題。我們知道,身份證的最後一位為校驗位,那麼最後一位是怎麼得到的呢?原來,最後一位是由數字1-9組成,超過9的比如11就用字母X表示,否則號碼就變成了19位。瞭解了這些,經過整理得出身份證補全演算法實現思想如下:

step1、將15位身份證號碼加入出生年變為17位

step2、將step1得到的身份證17位數分別乘以不同的係數。從第1位到第17位的係數分別為:7-9-10-5-8-4-2-1-6-3-7-9-10-5-8-4-2.

step3、將這17位數字和係數相乘的結果相加

step4、將step3的結果除以11,得出餘數

由於數字的特殊性,這些餘數只可能是0-10這11個數字,身份證最後一位的對應數字為1-0-X-9-8-7-6-5-4-3-2.。例上面的餘數結果為3那麼對應身份證號碼的最後一位就是9,如果是10,身份證最後一位便是2。

程式碼如下:

測試結果如下:

1153367-20170619213856382-410871354

三、總結

身份證號碼補全雖然簡單,但是前提需要了解我國公民的身份證構成原理才能正確驗證,今天將這個學習過程分享給大家,希望對大家有所幫助,學習是個永無止境的過程,只有不斷學習才能有進步!

相關文章