前言
最近在參與一個銀行項目-某銀行安防系統-反洗錢需求的開發,銀行項目的離不開身份證號碼,身份證號碼作為我國公民的唯一標識,有這非同尋常的意義,由于業務的要求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。
代碼如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
|
public static void main(String[] args) { System.out.println(transIDCard15to18( "370986890623212" )); System.out.println(transIDCard15to18( "370725881105149" )); } /** * @param IdCardNO * @return 18位標準身份證號 * 方法用途:15位身份證轉化為18位標準證件號 * @return String * @author 我心自在 */ public static String transIDCard15to18(String IdCardNO){ String cardNo= null ; if ( null !=IdCardNO&&IdCardNO.trim().length()== 15 ){ IdCardNO=IdCardNO.trim(); StringBuffer sb= new StringBuffer(IdCardNO); sb.insert( 6 , "19" ); sb.append(transCardLastNo(sb.toString())); cardNo=sb.toString(); } return cardNo; } /** * 方法用途:15位補全‘19'位后的身份證號碼 * @param newCardId * @return * @return String * @author 我心自在 */ private static String transCardLastNo(String newCardId){ char [] ch=newCardId.toCharArray(); int m= 0 ; int [] co={ 7 , 9 , 10 , 5 , 8 , 4 , 2 , 1 , 6 , 3 , 7 , 9 , 10 , 5 , 8 , 4 , 2 }; char [] verCode= new char []{ '1' , '0' , 'X' , '9' , '8' , '7' , '6' , '5' , '4' , '3' , '2' }; for ( int i = 0 ; i < newCardId.length(); i++) { m+=(ch[i]- '0' )*co[i]; } int residue=m% 11 ; return String.valueOf(verCode[residue]); } |
測試結果如下:
三、總結
身份證號碼補全雖然簡單,但是前提需要了解我國公民的身份證構成原理才能正確驗證,今天將這個學習過程分享給大家,希望對大家有所幫助,學習是個永無止境的過程,只有不斷學習才能有進步!
好了,以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作能帶來一定的幫助,如果有疑問大家可以留言交流,謝謝大家對服務器之家的支持。
原文鏈接:http://www.cnblogs.com/10158wsj/p/7050736.html