身份证号码算法解析与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));
    }
}

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

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

相关推荐
isyangli_blog几秒前
(1-4)Java Object类、Final、注解、设计模式、抽象类、接口、内部类
java·开发语言
liang_20266 分钟前
【HT周赛】T3.二维平面 题解(分块:矩形chkmax,求矩形和)
数据结构·笔记·学习·算法·平面·总结
緈福的街口7 分钟前
【leetcode】2900. 最长相邻不相等子序列 I
算法·leetcode·职场和发展
易只轻松熊9 分钟前
C++(20): 文件输入输出库 —— <fstream>
开发语言·c++·算法
远瞻。29 分钟前
【论文阅读】人脸修复(face restoration ) 不同先验代表算法整理
论文阅读·算法
进击的小白菜34 分钟前
LeetCode 153. 寻找旋转排序数组中的最小值:二分查找法详解及高频疑问解析
数据结构·算法·leetcode
dog2501 小时前
BBR 的 buffer 动力学观感
人工智能·算法
秋野酱1 小时前
Spring Boot 项目的计算机专业论文参考文献
java·spring boot·后端
士别三日&&当刮目相看1 小时前
数据结构*优先级队列(堆)
java·数据结构
香饽饽~、1 小时前
【第二篇】 初步解析Spring Boot
java·spring boot·后端