身份证号码算法解析与Java代码实现

中国的身份证号码是一串唯一的标识符,由18位数字组成,用于标识中国公民的个人信息。它不仅包含个人的出生日期和顺序码,还包含了地区信息。下面我们将介绍中国身份证号码的结构以及验证算法,并提供了相应的Java代码示例。

身份证号码结构

  1. 前1-6位代表所在地区的行政区划代码。
  2. 第7-14位代表持有人的出生年月日,例如19900101代表1990年1月1日。
  3. 第15-17位是同一地区、同一出生日期和同一性别的人的顺序码。
  4. 第18位为校验码,用于验证身份证号码的有效性。

身份证号码验证算法

根据中国身份证号码的编码规则,可以通过以下步骤验证身份证号码的有效性:

  1. 首先使用正则表达式验证身份证号码的基本格式是否正确。
  2. 接着计算前17位的加权和,加权系数为固定值。
  3. 根据加权和计算出的结果,与校验码进行比对验证身份证号码的正确性。

以下是用Java实现的身份证号码验证代码示例:

java 复制代码
javaCopy code
import java.util.regex.Pattern;

public class ChineseIDValidator {

    public static boolean isValidID(String id) {
        String pattern = "^[1-9]\\d{16}[0-9Xx]$";
        if (!Pattern.matches(pattern, id)) {
            return false;
        }

        // 获取身份证前17位
        String id17 = id.substring(0, 17);
        char[] chars = id17.toCharArray();
        int[] coefficient = { 7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2 };
        char[] verifyCode = {'1', '0', 'X', '9', '8', '7', '6', '5', '4', '3', '2'};
        int sum = 0;
        for (int i = 0; i < 17; i++) {
            sum += (chars[i] - '0') * coefficient[i];
        }
        char lastChar = id.charAt(17);
        if (lastChar == 'x' || lastChar == 'X') {
            lastChar = 'X';
        }
        return lastChar == verifyCode[sum % 11];
    }

    public static void main(String[] args) {
        String id1 = "11010519491231002X";
        String id2 = "11010519491231002x";
        String id3 = "12345678901234567";
        System.out.println(id1 + " is valid: " + isValidID(id1));
        System.out.println(id2 + " is valid: " + isValidID(id2));
        System.out.println(id3 + " is valid: " + isValidID(id3));
    }
}

以上代码示例通过正则表达式验证身份证号码格式的正确性,并使用特定的算法验证了身份证号码的合法性。

希望本文能够帮助读者了解中国身份证号码的编码规则以及验证算法,并在实际应用中起到一定的指导作用。

相关推荐
复杂网络1 小时前
多个 Claude Code 与多个 Codex 协同工作:设计与实现方案
算法
荣码1 小时前
LLM结构化输出:让AI返回JSON而不是废话,我踩了4个坑
java·python
plainGeekDev3 小时前
Gson → kotlinx.serialization
android·java·kotlin
小bo波11 小时前
Java Swing 图形用户界面实验 —— 从算术练习到游戏开发的完整实践
java·课程设计·gui·游戏开发·扫雷·swing
咖啡八杯13 小时前
GoF设计模式——备忘录模式
java·后端·spring·设计模式
HjhIron16 小时前
面试常客:字符串算法从入门到进阶
算法·面试
吴佳浩18 小时前
DeepSeek DSpark:Confidence-Scheduled Speculative Decoding 技术解析
人工智能·算法·deepseek
触底反弹19 小时前
🧠 搞懂 Token,才算真正入门大模型——从分词原理到 Embedding 语义实战
javascript·人工智能·算法