2f6a585ba61662149d3350332bd616342e7976cf.svn-base 10.1 KB
package com.thinkgem.jeesite.modules.reg.web.bus;

import java.text.SimpleDateFormat;
import java.util.Calendar;
import java.util.GregorianCalendar;
import java.util.Hashtable;
import java.util.List;
import java.util.regex.Matcher;
import java.util.regex.Pattern;

import javax.servlet.http.HttpServletRequest;

import org.apache.shiro.authz.annotation.RequiresPermissions;
import org.springframework.ui.ModelMap;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.ResponseBody;

import com.opensymphony.module.sitemesh.util.Container;
import com.thinkgem.jeesite.common.utils.StringUtils;
import com.thinkgem.jeesite.modules.reg.entity.bus.RegBaseZdjbxxdr;
import com.thinkgem.jeesite.modules.reg.entity.bus.RegBusHisHouseQlr;
import com.thinkgem.jeesite.modules.sys.utils.DictUtils;

public class RegBusUtils {
	/** 
     * 验证身份证 
     * @param IDStr 
     * @return "YES" 代表合法的身份证 ,其他值代表错误信息 
     * @throws ParseException 
     */  
    public String IDCardValidate(String IDStr,String zjzl) {  
        String tipInfo = "YES";// 记录错误信息  
        String Ai = "";  
        //身份证号
        if("1".equals(zjzl)){  
	        if(null == IDStr || IDStr.trim().isEmpty())  
	            return "身份证号码长度应该为15位或18位。";  
	          
	        // 判断号码的长度 15位或18位  
	        if (IDStr.length() != 15 && IDStr.length() != 18) {  
	            tipInfo = "身份证号码长度应该为15位或18位。";  
	            return tipInfo;  
	        }
	        // 18位身份证前17位位数字,如果是15位的身份证则所有号码都为数字  
	        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) {  
	            tipInfo = "身份证15位号码都应为数字 ; 18位号码除最后一位外,都应为数字。";  
	            return tipInfo;  
	        }  
	        // 判断出生年月是否有效  
	        String strYear = Ai.substring(6, 10);// 年份 
	        String strMonth = Ai.substring(10, 12);// 月份  
	        String strDay = Ai.substring(12, 14);// 日期  
	        if (isDate(strYear + "-" + strMonth + "-" + strDay) == false) {  
	            tipInfo = "身份证出生日期无效。";  
	            return tipInfo;
	        }  
	        GregorianCalendar gc = new GregorianCalendar();  
	        SimpleDateFormat s = new SimpleDateFormat("yyyy-MM-dd");  
	        try {  
	            if ((gc.get(Calendar.YEAR) - Integer.parseInt(strYear)) > 150  
	                    || (gc.getTime().getTime() - s.parse(strYear + "-" + strMonth + "-" + strDay).getTime()) < 0) {  
	                tipInfo = "身份证生日不在有效范围。";  
	                return tipInfo;  
	            }  
	        } catch (NumberFormatException e) {  
	            e.printStackTrace();  
	        } catch (java.text.ParseException e) {  
	            e.printStackTrace();  
	        }  
	        if (Integer.parseInt(strMonth) > 12 || Integer.parseInt(strMonth) == 0) {  
	            tipInfo = "身份证月份无效";  
	            return tipInfo;  
	        }  
	        if (Integer.parseInt(strDay) > 31 || Integer.parseInt(strDay) == 0) {  
	            tipInfo = "身份证日期无效";  
	            return tipInfo;  
	        }  
	        // 判断地区码是否有效  
	        Hashtable areacode = GetAreaCode();  
	        // 如果身份证前两位的地区码不在Hashtable,则地区码有误  
	        if (areacode.get(Ai.substring(0, 2)) == null) {  
	            tipInfo = "身份证地区编码错误。";  
	            return tipInfo;  
	        }  
	        if (isVarifyCode(Ai, IDStr) == false) {  
	            tipInfo = "身份证校验码无效,不是合法的身份证号码";  
	            return tipInfo;  
	        }  
        }
        //组织机构代码
        if("6".equals(zjzl)){ 
        	 if(iszzjgdm(IDStr) == false) {  
        		tipInfo = " 组织机构代码输入不合法!";  
 	            return tipInfo;  
        	 }
        }
        //营业执照
        if("7".equals(zjzl)){ 
        	if(isyyzz(IDStr) == false) {  
        		tipInfo = "营业执照输入不合法!";  
	            return tipInfo;  
        	 }
        }
//        if(!"7".equals(zjzl) && !"6".equals(zjzl) && !"1".equals(zjzl)){ 
//        	if(isqtzjlx(IDStr) == false) {  
//        		tipInfo = "【其他】证件类型只能以数字开头!";  
//	            return tipInfo;  
//        	 }
//        }
        return tipInfo;  
    }  
  
    /* 
     * 判断第18位校验码是否正确 第18位校验码的计算方式: 1. 对前17位数字本体码加权求和 公式为:S = Sum(Ai * Wi), i = 
     * 0, ... , 16 其中Ai表示第i个位置上的身份证号码数字值,Wi表示第i位置上的加权因子,其各位对应的值依次为: 7 9 10 5 8 4 
     * 2 1 6 3 7 9 10 5 8 4 2 2. 用11对计算结果取模 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 
     */  
    private static boolean isVarifyCode(String Ai, String IDStr) {  
        String[] VarifyCode = { "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" };  
        int sum = 0;  
        for (int i = 0; i < 17; i++) {  
            sum = sum + Integer.parseInt(String.valueOf(Ai.charAt(i))) * Integer.parseInt(Wi[i]);  
        }  
        int modValue = sum % 11;  
        String strVerifyCode = VarifyCode[modValue];  
        Ai = Ai + strVerifyCode;  
        if (IDStr.length() == 18) {  
            if (Ai.equals(IDStr) == false) {  
                return false;  
            }  
        }  
        return true;  
    }  
  
    /** 
     * 将所有地址编码保存在一个Hashtable中 
     *  
     * @return Hashtable 对象 
     */  
    private static 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;  
    }  
  
    /** 
     * 判断字符串是否为数字,0-9重复0次或者多次 
     *  
     * @param strnum 
     * @return 
     */  
    private static boolean isNumeric(String strnum) {  
        Pattern pattern = Pattern.compile("[0-9]*");  
        Matcher isNum = pattern.matcher(strnum);  
        if (isNum.matches()) {  
            return true;  
        } else {  
            return false;  
        }  
    }  
  
    /** 
     * 功能:判断字符串出生日期是否符合正则表达式:包括年月日,闰年、平年和每月31天、30天和闰月的28天或者29天 
     *  
     * @param string 
     * @return 
     */  
    public static 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][1235679])|([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]))))))?$");  
        Matcher m = pattern.matcher(strDate);  
        if (m.matches()) {  
            return true;  
        } else {  
            return false;  
        }  
    } 
	
	/**
	  * 功能:判断组织机构代码的合法性
     *  
     * @param string 
     * @return 
	 */
    public static boolean iszzjgdm(String IDStr) {  
        Pattern pattern = Pattern.compile("^[a-zA-Z\\d]{8}\\-[a-zA-Z\\d]$");  
        Matcher m = pattern.matcher(IDStr);  
        if (m.matches()) {  
            return true;  
        } else {  
            return false;  
        }  
    } 
	    
    /**
	  * 功能:判断营业执照的合法性
    *  
    * @param string 
    * @return 
	 */
   public static boolean isyyzz(String IDStr) {  
       Pattern pattern = Pattern.compile("^\\d{15}$|^[0-9a-zA-Z]{18}$");  
       Matcher m = pattern.matcher(IDStr);  
       if (m.matches()) {  
           return true;  
       } else {  
           return false;  
       }  
   } 
   
   /**
	  * 功能:判断其它证件类型的合法性
	  *  
	  * @param string 
	  * @return 
	*/
    public static boolean isqtzjlx(String IDStr) {  
	     Pattern pattern = Pattern.compile("^[0-9].*$");  
	     Matcher m = pattern.matcher(IDStr);  
	     if (m.matches()) {  
	         return true;  
	     } else {  
	         return false;  
	     }  
    } 
}