登录
首页 >  文章 >  常见问题

身份证最后一位怎么算?校验码原理详解

时间:2026-03-06 18:34:33 372浏览 收藏

你是否好奇身份证最后一位数字或字母“X”究竟是如何生成的?它并非随意填写,而是通过一套严谨的数学算法——基于前17位数字加权求和、模11取余、再查表映射得出,其中“X”专用于表示余数2,兼顾唯一性、抗错性和国际标准兼容性;无论你是想手动验真、理解国标原理,还是开发身份核验功能,掌握这一校验码机制,都能让你一眼识破无效号码,真正看懂身份证背后的密码逻辑。

身份证第18位怎么算_身份证号码最后一位校验码原理

如果您查看一张居民身份证,发现第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调整偏移)。

以上就是本文的全部内容了,是否有顺利帮助你解决问题?若是能给你带来学习上的帮助,请大家多多支持golang学习网!更多关于文章的相关知识,也可关注golang学习网公众号。

资料下载
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>