-
- 身份證号碼結構
-
- 組成說明
- 計算方法
- 代碼驗證
身份證号碼結構
組成說明
公民身份号碼是特征組合碼,由十七位數字本體碼和一位數字校驗碼組成。
- 前6位為位址碼,以數字1-9開頭,後5位為0-9的數字;
- 第7位至14位為出生日期碼,此碼由6位數改為8位數,其中年份用4位數表示;
- 第15位至17位為順序碼,是縣、區級政府所轄派出所的配置設定碼;
- 第18位為校驗碼,主要是為了校驗計算機輸入公民身份證号碼的前17位數字是否正确,其取值範圍是0至10,當值等于10時,用羅馬數字元X表示。
注: 一代身份證(15位)已經不能使用,需要換領二代身份證(18位)。
計算方法
- 将前面的身份證号碼17位數分别乘以不同的系數。從第一位到第十七位的系數分别為:7-9-10-5-8-4-2-1-6-3-7-9-10-5-8-4-2。
- 将這17位數字和系數相乘的結果相加。
- 用加出來和除以11,看餘數是多少?
- 餘數隻可能有0-1-2-3-4-5-6-7-8-9-10這11個數字。其分别對應的最後一位身份證的号碼為1-0-X -9-8-7-6-5-4-3-2。(即餘數0對應1,餘數1對應0,餘數2對應X…)
- 通過上面得知如果餘數是3,就會在身份證的第18位數字上出現的是9。如果對應的數字是2,身份證的最後一位号碼就是羅馬數字X。
舉個例子: 某男性的身份證号碼為【53010219200508011X】, 我們看看這個身份證是不是符合計算規則的身份證?
首先我們得出前17位的乘積和【(57)+(39)+(010)+(15)+(08)+(24)+(12)+(91)+(26)+(03)+(07)+(59)+(010)+(85)+(08)+(14)+(1*2)】是189,然後用189除以11得出的結果是189÷11=17餘下2,187÷11=17,還剩下2不能被除盡,也就是說其餘數是2。最後通過對應規則就可以知道餘數2對應的檢驗碼是X。是以,可以判定這是一個正确的身份證号碼.
代碼驗證
現在身份證号碼基本都是18位的(本文不對15位身份證做驗證處理)。
當身份證号碼為15位時,全部都是數字。當為18位時,前17位全部為數字後1位為檢驗位,可能為數字,也可能為字母X。
/**
* 驗證身份證号碼
* @param { String } code 身份證号碼
*/
function identityIDCard(code) {
// 身份證号前兩位代表區域
const city = {
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: '國外 ',
};
const idCardReg = /^[1-9]\d{5}(19|20)?\d{2}(0[1-9]|1[012])(0[1-9]|[12]\d|3[01])\d{3}(\d|X)$/i; // 身份證格式正規表達式
let errorMessage = ''; // 錯誤提示資訊
let isPass = true; // 身份證驗證是否通過(true通過、false未通過)
// 如果身份證不滿足格式正規表達式
if (!code) {
errorMessage = '請輸入身份證号碼';
isPass = false;
} else if (!code.match(idCardReg)) {
errorMessage = '請輸入正确的身份證号碼';
isPass = false;
} else if (!city[code.substr(0, 2)]) {
// 區域數組中不包含需驗證的身份證前兩位
errorMessage = '請輸入正确的身份證号碼';
isPass = false;
} else if (code.length === 18) {
// 18位身份證需要驗證最後一位校驗位
code = code.split('');
// ∑(ai×Wi)(mod 11)
// 權重因子
const factor = [7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2];
// 校驗位
const parity = [1, 0, 'X', 9, 8, 7, 6, 5, 4, 3, 2];
let sum = 0;
let ai = 0;
let wi = 0;
for (let i = 0; i < 17; i++) {
ai = parseInt(code[i]);
wi = factor[i];
sum += ai * wi; // 開始計算并相加
}
const last = parity[sum % 11]; // 求餘
if (last.toString() !== code[17]) {
errorMessage = '請輸入正确的身份證号碼';
isPass = false;
}
}
return {
errorMessage,
isPass,
}
}