package com.common.test; import java.sql.Connection; import java.sql.DriverManager; import java.sql.PreparedStatement; import java.sql.ResultSet; import java.sql.SQLException; import java.sql.Statement; import java.text.ParseException; import java.text.SimpleDateFormat; import java.util.Calendar; import java.util.GregorianCalendar; import java.util.Hashtable; import java.util.regex.Matcher; import java.util.regex.Pattern; /** *<p>Title:</p> *<p>Description: </p> *<p>Copyright: Copyright (c) 2008</p> *<p>Company: JFZX</p> *<p>CreateDate: 2009-6-19</p> * @author LiuJW */ public class Db { /** 1、号码的结构 公民身份号码是特征组合码,由十七位数字本体码和一位校验码组成。排列顺序从左至右依次为:六位数字地址码,八位数字出生日期码,三位数字顺序码和一位数字校验码。 2、地址码(前六位数) 表示编码对象常住户口所在县(市、旗、区)的行政区划代码,按GB/T2260的规定执行。 3、出生日期码(第七位至十四位) 表示编码对象出生的年、月、日,按GB/T7408的规定执行,年、月、日代码之间不用分隔符。 4、顺序码(第十五位至十七位) 表示在同一地址码所标识的区域范围内,对同年、同月、同日出生的人编定的顺序号,顺序码的奇数分配给男性,偶数分配给女性。 5、校验码(第十八位数) (1)十七位数字本体码加权求和公式 S = Sum(Ai * Wi), i = 0, ... , 16 ,先对前17位数字的权求和 Ai:表示第i位置上的身份证号码数字值 Wi:表示第i位置上的加权因子 Wi: 7 9 10 5 8 4 2 1 6 3 7 9 10 5 8 4 2 (2)计算模 Y = mod(S, 11) (3)通过模得到对应的校验码 Y: 0 1 2 3 4 5 6 7 8 9 10 校验码: 1 0 X 9 8 7 6 5 4 3 2 所以我们就可以大致写一个函数来校验是否正确了。 */ /**====================================================================== * 功能:身份证的有效验证 * @param IDStr 身份证号 * @return 有效:true 无效:false * @throws ParseException */ public String IDCardValidate(String IDStr) throws ParseException { String errorInfo = "";//记录错误信息 String[] ValCodeArr = {"1","0","x","9","8","7","6","5","4","3","2"}; String[] Wi = {"7","9","10","5","8","4","2","1","6","3","7","9","10","5","8","4","2"}; //String[] Checker = {"1","9","8","7","6","5","4","3","2","1","1"}; String Ai=""; //================ 号码的长度 15位或18位 ================ if(IDStr.length()!=15 && IDStr.length()!=18) { errorInfo="号码长度应该为15位或18位。"; // System.out.println(errorInfo); return errorInfo; } //=======================(end)======================== //================ 数字 除最后一位都为数字 ================ if(IDStr.length()==18) { Ai=IDStr.substring(0,17); } else if(IDStr.length()==15) { Ai=IDStr.substring(0,6)+"19"+IDStr.substring(6,15); } if(isNumeric(Ai)==false) { errorInfo="15位号码都应为数字 ; 18位号码除最后一位外,都应为数字。"; // System.out.println(errorInfo); return errorInfo; } //=======================(end)======================== //================ 出生年月是否有效 ================ String strYear =Ai.substring(6 ,10);//年份 String strMonth=Ai.substring(10,12);//月份 String strDay =Ai.substring(12,14);//天 if(this.isDate(strYear+"-"+strMonth+"-"+strDay)==false) { errorInfo="生日无效。"; // System.out.println(errorInfo); return errorInfo; } GregorianCalendar gc=new GregorianCalendar(); SimpleDateFormat s=new SimpleDateFormat("yyyy-MM-dd"); if((gc.get(Calendar.YEAR)-Integer.parseInt(strYear))>150 || (gc.getTime().getTime()-s.parse(strYear+"-"+strMonth+"-"+strDay).getTime())<0) //年龄大于150岁 或日期在今天之后 { errorInfo="生日不在有效范围。"; // System.out.println(errorInfo); return errorInfo; } if(Integer.parseInt(strMonth)>12 || Integer.parseInt(strMonth)==0) { errorInfo="月份无效"; // System.out.println(errorInfo); return errorInfo; } if(Integer.parseInt(strDay)>31 || Integer.parseInt(strDay)==0) { errorInfo="日期无效"; // System.out.println(errorInfo); return errorInfo; } //=====================(end)===================== //================ 地区码时候有效 ================ Hashtable h=GetAreaCode(); if(h.get(Ai.substring(0,2))==null) { errorInfo="地区编码错误。"; // System.out.println(errorInfo); return errorInfo; } //============================================== //================ 判断最后一位的值 =============== int TotalmulAiWi=0; for(int i=0 ; i<17 ; i++) { TotalmulAiWi = TotalmulAiWi + Integer.parseInt(String.valueOf(Ai.charAt(i))) * Integer.parseInt(Wi[i]); } int modValue=TotalmulAiWi % 11; String strVerifyCode=ValCodeArr[modValue]; Ai=Ai+strVerifyCode; if(IDStr.length()==18) { if(Ai.equals(IDStr)==false) { errorInfo="身份证无效,第18位校验位有错"; // System.out.println(errorInfo); return errorInfo; } }else{ // System.out.println("所在地区:"+h.get(Ai.substring(0,2).toString())); // System.out.println("新身份证号:"+Ai); return errorInfo; } //=====================(end)===================== // System.out.println("所在地区:"+h.get(Ai.substring(0,2).toString())); return errorInfo; } /** *//**====================================================================== * 功能:设置地区编码 * @return Hashtable 对象 */ private Hashtable GetAreaCode() { Hashtable hashtable=new Hashtable(); hashtable.put("11","北京"); hashtable.put("12","天津"); hashtable.put("13","河北"); hashtable.put("14","山西"); hashtable.put("15","内蒙古"); hashtable.put("21","辽宁"); hashtable.put("22","吉林"); hashtable.put("23","黑龙江"); hashtable.put("31","上海"); hashtable.put("32","江苏"); hashtable.put("33","浙江"); hashtable.put("34","安徽"); hashtable.put("35","福建"); hashtable.put("36","江西"); hashtable.put("37","山东"); hashtable.put("41","河南"); hashtable.put("42","湖北"); hashtable.put("43","湖南"); hashtable.put("44","广东"); hashtable.put("45","广西"); hashtable.put("46","海南"); hashtable.put("50","重庆"); hashtable.put("51","四川"); hashtable.put("52","贵州"); hashtable.put("53","云南"); hashtable.put("54","西藏"); hashtable.put("61","陕西"); hashtable.put("62","甘肃"); hashtable.put("63","青海"); hashtable.put("64","宁夏"); hashtable.put("65","新疆"); hashtable.put("71","台湾"); hashtable.put("81","香港"); hashtable.put("82","澳门"); hashtable.put("91","国外"); return hashtable; } /** *//**====================================================================== * 功能:判断字符串是否为数字 * @param str * @return */ private boolean isNumeric(String str) { Pattern pattern=Pattern.compile("[0-9]*"); Matcher isNum=pattern.matcher(str); if(isNum.matches()) { return true; }else{ return false; } /**//*判断一个字符时候为数字 if(Character.isDigit(str.charAt(0))) { return true; } else { return false; }*/ } /** *//**====================================================================== * 功能:判断字符串是否为日期格式 * @param str * @return */ public boolean isDate(String strDate) { // Pattern pattern = Pattern.compile("^((//d{2}(([02468][048])|([13579][26]))[s]?((((0?" + // "[13578])|(1[02]))[s]?((0?[1-9])|([1-2][0-9])|(3[01])))" + // "|(((0?[469])|(11))[s]?((0?[1-9])|([1-2][0-9])|(30)))|" + // "(0?2[s]?((0?[1-9])|([1-2][0-9])))))|(//d{2}(([02468][12" + // "35679])|([13579][01345789]))[s]?((((0?[13578])|(1[02]))" + // "[s]?((0?[1-9])|([1-2][0-9])|(3[01])))|(((0?[469])|(11))" + // "[s]?((0?[1-9])|([1-2][0-9])|(30)))|(0?2[s]?((0?[" + // "1-9])|(1[0-9])|(2[0-8]))))))"); // Pattern pattern = Pattern.compile("(?:[0-9]{1,4}(?<!^0?0?0?0))-(?:0[1-9]|1[0-2])-(?:0[1-9]|1[0-9]|2[0-8]| (?:(?<=(?:0[13578]|1[02])-)(?:29|3[01]))|(?:(?<=(?:0[469]|11)-)(?:29|30))| (?:(?<=(?:(?:[0-9]{0,2}(?!0?0)(?:[02468]?(?<![13579])[048]|[13579][26]))| (?:(?:[02468]?[048]|[13579][26])00))-02-)(?:29)))"); Pattern pattern = Pattern .compile("^(?:([0-9]{4}-(?:(?:0?[1,3-9]|1[0-2])-(?:29|30)|" + "((?:0?[13578]|1[02])-31)))|" + "([0-9]{4}-(?:0?[1-9]|1[0-2])-(?:0?[1-9]|1//d|2[0-8]))|" + "(((?:(//d//d(?:0[48]|[2468][048]|[13579][26]))|" + "(?:0[48]00|[2468][048]00|[13579][26]00))-0?2-29)))$"); Matcher m=pattern.matcher(strDate); if(m.matches()) { return true; } else { return false; } } /**//*======================================================================= *功能:在判定已经是正确的身份证号码之后,查找出身份证所在地区 *@param idCard 身份证号码 *@return 所在地区 */ public String GetArea(String idCard){ Hashtable ht = GetAreaCode(); String area = (String)ht.get(idCard.substring(0,2)); return area; } /**//*======================================================================= *功能:在判定已经是正确的身份证号码之后,查找出此人性别 *@param idCard 身份证号码 *@return 男或者女 */ public String GetSex(String idCard){ String sex = ""; if(idCard.length()==15) sex = idCard.substring(idCard.length()-3,idCard.length()); if(idCard.length()==18) sex = idCard.substring(idCard.length()-4,idCard.length()-1); // System.out.println(sex); int sexNum = Integer.parseInt(sex)%2; if(sexNum == 0){ return "女"; } return "男"; } /**//*======================================================================= *功能:在判定已经是正确的身份证号码之后,查找出此人出生日期 *@param idCard 身份证号码 *@return 出生日期 XXXX MM-DD */ public String GetBirthday(String idCard){ String Ain = ""; if(idCard.length()==18){ Ain=idCard.substring(0,17); } else if(idCard.length()==15){ Ain=idCard.substring(0,6)+"19"+idCard.substring(6,15); } //================ 出生年月是否有效 ================ String strYear =Ain.substring(6 ,10);//年份 String strMonth=Ain.substring(10,12);//月份 String strDay =Ain.substring(12,14);//日期 return strYear+"-"+strMonth+"-"+strDay; } /** *//** * @param args * @throws ParseException */ public static void main(String[] args) throws ParseException{ // Db db = new Db(); // System.out.println(db.isDate("2008-03-30")); try { Class.forName("net.sourceforge.jtds.jdbc.Driver").newInstance(); } catch (InstantiationException e) { // TODO Auto-generated catch block e.printStackTrace(); } catch (IllegalAccessException e) { // TODO Auto-generated catch block e.printStackTrace(); } catch (ClassNotFoundException e) { // TODO Auto-generated catch block e.printStackTrace(); } String url="jdbc:jtds:sqlserver://192.168.0.155:1434/zfbz_hhht"; // mydb为数据库 String user="sa"; String password="ok"; Connection conn = null; Statement stmt = null; PreparedStatement ps=null; ResultSet rs = null; try { conn= DriverManager.getConnection(url,user,password); stmt=conn.createStatement(); String sql="select f.lawsection,f.lawstreet,f.lawCommittee,p.name,p.idcard from lzfamilyinfo f,lzfamilyperson p where " + "f.familycode=p.familycode and f.lawcity= '1531' order by f.lawsection"; rs = stmt.executeQuery(sql); int num = 1; Db db = new Db(); while(rs.next()){ String name = rs.getString("name"); String idcard = rs.getString("idcard"); // int num1 = num++; // System.out.println("name="+name+" idcard="+idcard+" 第"+num1+"条数据!"); if(!"".equals(db.IDCardValidate(idcard))){ //如果不为空,则说明号码不正确 int num1 = num++; System.out.println("name="+name+" idcard="+idcard+" 第"+num1+"错误条数据!"+"错误原因:"+db.IDCardValidate(idcard)); sql = "insert into tempTable values(?,?,?)"; ps = conn.prepareStatement(sql); ps.setString(1, name); ps.setString(2, idcard); ps.setString(3, db.IDCardValidate(idcard)); ps.execute(); } } } catch (Exception e) { // TODO Auto-generated catch block e.printStackTrace(); } finally{ try { stmt.close(); conn.close(); } catch (SQLException e) { // TODO Auto-generated catch block e.printStackTrace(); } } } } 在网上搜了以部分代码 又修改过 保证可以用