身份证第18位校验码由前17位加权求和后模11,再按余数查表得出:余数0-10对应字符“10X98765432”,其中X代表余数2。

如果您查看一张居民身份证,发现第18位是数字或字母X,却不清楚其生成逻辑,则可能是由于未掌握校验码的数学推导过程。以下是计算身份证第18位校验码的具体方法:
一、加权求和法
该方法依据国家标准GB 11643-1999,通过前17位数字与固定加权因子逐位相乘后累加,为后续模运算提供基础值。加权因子序列具有唯一性,不可替换或调序。
1、将身份证号码前17位数字依次写出:例如23038219991011816。
2、对应每一位数字,分别乘以加权因子:7、9、10、5、8、4、2、1、6、3、7、9、10、5、8、4、2。
3、逐位相乘后,将17个乘积全部相加,得出总和S。
二、模11取余法
该步骤利用整数除法的余数特性,将加权和映射至有限集合{0,1,…,10},从而限定校验码的映射输入范围,确保算法可逆且抗干扰。
1、用加权总和S除以11,仅保留余数R(即计算 S mod 11)。
2、确认R的取值严格落在0至10之间(含端点),超出此范围说明加权求和过程存在错位或漏乘。
三、余数查表映射法
该步骤将抽象余数转化为可读字符,其中X作为罗马数字替代符,专用于表示余数2的情形,避免与数字混淆并符合ISO/IEC标准兼容性要求。
1、根据余数R查对应校验码表:R=0→1,R=1→0,R=2→X,R=3→9,R=4→8,R=5→7,R=6→6,R=7→5,R=8→4,R=9→3,R=10→2。
2、将查得的字符直接作为身份证第18位填写。
四、手工验算验证法
该方法不依赖电子工具,适用于无网络环境下的即时核验,通过反向代入已知完整号码,复现加权—求和—取余—查表全过程,判断原证是否符合编码规则。
1、从身份证号码中分离出前17位数字与第18位字符。
2、按前述加权因子重复执行加权求和与模11运算,得到理论余数R′。
3、将R′代入查表规则,比对所得字符是否与原始第18位完全一致。
五、程序化自动计算法
该方法适用于批量处理场景,将校验逻辑封装为函数,输入17位字符串即可输出合法校验码,广泛应用于公安系统后台、政务服务平台及身份核验SDK中。
1、定义常量字符串xs = "7910584216379105842"(共17组两位系数,注意无分隔符)。
2、定义查表字符串checkCodeStr = "10X98765432"(长度为11,索引0对应余数0)。
3、遍历前17位,提取每位数字与对应系数相乘并累加;计算sum mod 11,所得结果作为checkCodeStr的索引(需+1调整偏移)。









