Java检测身份证号的正确性

package test; public class test { public static void main(String[] args) { String IDNumber = "642221199505062528"; if("".equals(IDNumber) || IDNumber == null) { System.out.println("身份证号为空!"); } // 定义判别用户身份证号的正则表达式(15位或者18位,最后一位可以为字母) String regularExpression18 = "(^[1-9]\\d{5}(18|19|([23]\\d))\\d{2}((0[1-9])|(10|11|12))(([0-2][1-9])|10|20|30|31)\\d{3}[0-9Xx]$)"; String regularExpression15 = "(^[1-9]\\d{5}\\d{2}((0[1-9])|(10|11|12))(([0-2][1-9])|10|20|30|31)\\d{3}$)"; //方法简介 matches //语法 public boolean matches(String regex); //作用 该方法用于检测字符串是否匹配给定的正则表达式; //返回值 在字符串匹配给定的正则表达式时,返回true。 boolean matches = IDNumber.matches(regularExpression18)||IDNumber.matches(regularExpression15); //判断第18位校验值 if (matches) { if (IDNumber.length() == 18) { try { char[] charArray = IDNumber.toCharArray(); //前十七位加权因子 int[] idCardWi = {7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2}; //这是除以11后,可能产生的11位余数对应的验证码 String[] idCardY = {"1", "0", "X", "9", "8", "7", "6", "5", "4", "3", "2"}; int sum = 0; for (int i = 0; i < idCardWi.length; i++) { int current = Integer.parseInt(String.valueOf(charArray[i])); int count = current * idCardWi[i]; sum += count; } char idCardLast = charArray[17]; int idCardMod = sum % 11; if (idCardY[idCardMod].toUpperCase().equals(String.valueOf(idCardLast).toUpperCase())) { System.out.println("身份证号正确!"); } else { System.out.println("身份证最后一位:" + String.valueOf(idCardLast).toUpperCase() + "错误,正确的应该是:" + idCardY[idCardMod].toUpperCase()); } } catch (Exception e) { e.printStackTrace(); System.out.println("异常:" + IDNumber); } } } } }
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· 单线程的Redis速度为什么快?