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();
			}
		}
		
	}




}

在网上搜了以部分代码

又修改过

保证可以用