java校验身份证号码
- /**
- * 18位身份证校验,粗略的校验
- * @author lyl
- * @param idCard
- * @return
- */
- public static boolean is18ByteIdCard(String idCard){
- Pattern pattern1 = Pattern.compile("^(\\d{6})(19|20)(\\d{2})(1[0-2]|0[1-9])(0[1-9]|[1-2][0-9]|3[0-1])(\\d{3})(\\d|X|x)?$"); //粗略的校验
- Matcher matcher = pattern1.matcher(idCard);
- if(matcher.matches()){
- return true;
- }
- return false;
- }
- /**
- * 18位身份证校验,比较严格校验
- * @author lyl
- * @param idCard
- * @return
- */
- public static boolean is18ByteIdCardComplex(String idCard){
- Pattern pattern1 = Pattern.compile("^(\\d{6})(19|20)(\\d{2})(1[0-2]|0[1-9])(0[1-9]|[1-2][0-9]|3[0-1])(\\d{3})(\\d|X|x)?$");
- Matcher matcher = pattern1.matcher(idCard);
- int[] prefix = new int[]{7,9,10,5,8,4,2,1,6,3,7,9,10,5,8,4,2};
- int[] suffix = new int[]{ 1, 0, 10, 9, 8, 7, 6, 5, 4, 3, 2 };
- if(matcher.matches()){
- Map<String, String> cityMap = initCityMap();
- if(cityMap.get(idCard.substring(0,2)) == null ){
- return false;
- }
- int idCardWiSum=0; //用来保存前17位各自乖以加权因子后的总和
- for(int i=0;i<17;i++){
- idCardWiSum+=Integer.valueOf(idCard.substring(i,i+1))*prefix[i];
- }
- int idCardMod=idCardWiSum%11;//计算出校验码所在数组的位置
- String idCardLast=idCard.substring(17);//得到最后一位身份证号码
- //如果等于2,则说明校验码是10,身份证号码最后一位应该是X
- if(idCardMod==2){
- if(idCardLast.equalsIgnoreCase("x")){
- return true;
- }else{
- return false;
- }
- }else{
- //用计算出的验证码与最后一位身份证号码匹配,如果一致,说明通过,否则是无效的身份证号码
- if(idCardLast.equals(suffix[idCardMod]+"")){
- return true;
- }else{
- return false;
- }
- }
- }
- return false;
- }
- private static Map<String, String> initCityMap(){
- Map<String, String> cityMap = new HashMap<String, String>();
- cityMap.put("11", "北京");
- cityMap.put("12", "天津");
- cityMap.put("13", "河北");
- cityMap.put("14", "山西");
- cityMap.put("15", "内蒙古");
- cityMap.put("21", "辽宁");
- cityMap.put("22", "吉林");
- cityMap.put("23", "黑龙江");
- cityMap.put("31", "上海");
- cityMap.put("32", "江苏");
- cityMap.put("33", "浙江");
- cityMap.put("34", "安徽");
- cityMap.put("35", "福建");
- cityMap.put("36", "江西");
- cityMap.put("37", "山东");
- cityMap.put("41", "河南");
- cityMap.put("42", "湖北");
- cityMap.put("43", "湖南");
- cityMap.put("44", "广东");
- cityMap.put("45", "广西");
- cityMap.put("46", "海南");
- cityMap.put("50", "重庆");
- cityMap.put("51", "四川");
- cityMap.put("52", "贵州");
- cityMap.put("53", "云南");
- cityMap.put("54", "西藏");
- cityMap.put("61", "陕西");
- cityMap.put("62", "甘肃");
- cityMap.put("63", "青海");
- cityMap.put("64", "宁夏");
- cityMap.put("65", "新疆");
- // cityMap.put("71", "台湾");
- // cityMap.put("81", "香港");
- // cityMap.put("82", "澳门");
- // cityMap.put("91", "国外");
- // System.out.println(cityMap.keySet().size());
- return cityMap;
- }
java校验身份证号码的更多相关文章
- JAVA验证身份证号码是否正确
package com.IdCard; import java.text.SimpleDateFormat; import java.util.Calendar; import java.util.D ...
- JAVA通过身份证号码获取出生日期、年龄、性别
JAVA验证身份证号码是否正确:https://www.cnblogs.com/pxblog/p/12038278.html /** * 通过身份证号码获取出生日期(birthday).年龄(age) ...
- Java实现身份证号码校验
二话不说,直接上代码. package hope.identitycodecheck.demo; import java.text.DateFormat; import java.text.Simpl ...
- 【Java】身份证号码验证
代码引用自:https://gitee.com/appleat/codes/ynrtqujv0wfgesm8ia9b547 package xxx; /** * Created by wdj on 2 ...
- JAVA验证身份证号码是否合法
package com.chauvet.utils; import java.text.ParseException; import java.text.SimpleDateFormat; impor ...
- Java实现身份证号码验证源码分享
import java.text.ParseException; import java.text.SimpleDateFormat; import java.util.Calendar; impor ...
- Java的身份证号码工具类
/** * Copyright (C) 2009-2010 Yichuan, Fuchun All rights reserved. * Licensed to the Apache Software ...
- java验证身份证号码是否有效源代码 wn25的头像 wn25 23 2015-01-04 20:09 6 基本信息 Java × 1 浏览
原文:http://www.open-open.com/code/view/1420373343171 1.描述 用java语言判断身份证号码是否有效,地区码.出身年月.校验码等验证算法 2.源代码 ...
- java验证身份证号码是否有效源代码
原文:http://www.open-open.com/code/view/1420373343171 1.描述 用java语言判断身份证号码是否有效,地区码.出身年月.校验码等验证算法 2.源代码 ...
随机推荐
- Java JVM- jstat查看jvm的GC情况[转]
ava通过jvm自己管理内存,同时Java提供了一些命令行工具,用于查看内存使用情况.这里主要介绍一下jstat.jmap命令以及相关工具. 一.jstat查看 gc实时执行情况 jstat命令命令格 ...
- Python环境安装(Windows环境)
近半年来一直在用Python处理手头的工作.想想,Python确实是一门比较强大的语言,容易上手且功能强大, 基本上想做的工作都能找到别人提供的包. 目前主要在windows系统上办公,这里把wind ...
- ZOJ3591_Nim
题目的意思是给你n个ai,有多少种不同的连续段使得用该段数中所有的数字玩Nim游戏的先手必胜. 首先根据博弈论的知识,我们知道,要使先手必胜,那么只要保证所有的数的异或值不为0就可以了. 这个题目,给 ...
- Python常忘的基础知识
0.目录 1.进制 1.1 各进制的表示 1.2 各进制的转换 2.字符 2.1 转义字符 2.2 原始字符串 3.类型 3.1 基本数据类型 3.2 type() 4.变量与运算符 4.1 值类型与 ...
- jQuery高度及位置操作
1. 获取滑轮位置,scrolltop:上下滚动的意思. <!DOCTYPE html> <html lang="en"> <head> < ...
- Last Position of Target
For a given sorted array (ascending order) and a target number, find the first index of this number ...
- 使图片相对于上层DIV始终水平、垂直都居中
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...
- @RequestBody 和@ResponseBody 注解详解
简介: @RequestBody 作用: i) 该注解用于读取Request请求的body部分数据,使用系统默认配置的HttpMessageConverter进行解析,然后把相应的数据绑定到要返回的对 ...
- 省选模拟赛 LYK loves graph(graph)
题目描述 LYK喜欢花花绿绿的图片,有一天它得到了一张彩色图片,这张图片可以看做是一张n*m的网格图,每个格子都有一种颜色去染着,我们用-1至n*m-1来表示一个格子的颜色.特别地,-1代表这个颜色是 ...
- 对SLIP,PPP,PPPoE,EtherNet的理解。[zz]
经常看到PPP,PPPoE这些名词,当时也查了不少的资料,但是一直不太理解这是什么东西,干什么用的,今天静下心来,多看了点资料,有了一些初步理解,记录下来,以后有了新的理解再修改. 首先,SLIP ...