身份证校验器

身份证号码校验规则:

1、身份证号码是18位数,分别是17位数字和1位校验码。

具体含义分别是:6位地址码+8位出生日期+3位顺序码+1位校验码,校验码可能为字母

2、顺序码如果是奇数代表男性,偶数代表女性。

3、最后1位校验码是根据前17位数字算出来的

public final class IdCardUtil {
    private IdCardUtil() {
    }

    // 身份证校验码
    private static final int[] COEFFICIENT_ARRAY = {7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2};
    // 身份证号的尾数规则
    private static final String[] IDENTITY_MANTISSA = {"1", "0", "X", "9", "8", "7", "6", "5", "4", "3", "2"};
    private static final String IDENTITY_PATTERN = "^[0-9]{17}[0-9Xx]$";

    //校验身份证号是否合法
    public static boolean isLegalPattern(String identity) {
        if (identity == null || identity.length() != 18 || !identity.matches(IDENTITY_PATTERN)) {
            return false;
        }
        char[] chars = identity.toCharArray();
        long sum = IntStream.range(0, 17).map(index -> {
            char ch = chars[index];
            int digit = Character.digit(ch, 10);
            int coefficient = COEFFICIENT_ARRAY[index];
            return digit * coefficient;
        }).summaryStatistics().getSum();
        String mantissa = IDENTITY_MANTISSA[(int) (sum % 11)];
        return identity.substring(17).equalsIgnoreCase(mantissa);
    }
}

 

posted @   残城碎梦  阅读(68)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 使用C#创建一个MCP客户端
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· ollama系列1:轻松3步本地部署deepseek,普通电脑可用
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· 按钮权限的设计及实现
历史上的今天:
2021-11-26 常用的JVM参数
2021-11-26 Java程序生成Heap dump几种方式
2021-11-26 关于linux下,ls vi等命令失效的解决方法(配置下环境变量出现问题)
点击右上角即可分享
微信分享提示