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

2021-08-04 08:37:23 字數 1352 閱讀 8781

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

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

前六位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。

**實現

public

class idcarddemo

private

static string transidcard15to18(string idcardno)

return cardno;

}private

static string transcardlastno(string newcardid) ;

char vercode=new

char;

for (int i = 0; i < newcardid.length(); i++)

int residue=m%11;

return string.valueof(vercode[residue]);}}

身份證15位公升18位

六位數字位址碼 八位數字出生日期碼 三位數字順序碼 順序碼的奇數分給男性,偶數分給女性 一位數字校驗碼 校驗碼是根據前面十七位數字碼,按照iso 7064 1983.mod 11 2校驗碼計算出來的檢驗碼 1 多了年數 第6位開始多了19表示完整的出生日期 2 多了最後一位校驗碼 ai wi mod...

身份證15轉18位

身證份15位轉18位 測試用例用 顯示部分系統人為修改,create function f cid15to18 sfz char 18 returns char 18 asbegin declare osfz varchar 18 declare i int,ai int,wi int,sum in...

15位身份證 18位轉換

region 元件設計器生成的 web 服務設計器所必需的 private icontainer components null 設計器支援所需的方法 不要使用 編輯器修改 此方法的內容。private void initializecomponent 清理所有正在使用的資源。protected o...