All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.frameworkset.util.ValueObjectUtil Maven / Gradle / Ivy

Go to download

bboss is a j2ee framework include aop/ioc,mvc,persistent,taglib,rpc,event ,bean-xml serializable and so on.http://www.bbossgroups.com

There is a newer version: 6.2.7
Show newest version
/*****************************************************************************
 *                                                                           *
 *  This file is part of the tna framework distribution.                     *
 *  Documentation and updates may be get from  biaoping.yin the author of    *
 *  this framework							     							 *
 *                                                                           *
 *  Sun Public License Notice:                                               *
 *                                                                           *
 *  The contents of this file are subject to the Sun Public License Version  *
 *  1.0 (the "License"); you may not use this file except in compliance with *
 *  the License. A copy of the License is available at http://www.sun.com    *
 *                                                                           *
 *  The Original Code is tag. The Initial Developer of the Original          *
 *  Code is biaoping yin. Portions created by biaoping yin are Copyright     *
 *  (C) 2000.  All Rights Reserved.                                          *
 *                                                                           *
 *  GNU Public License Notice:                                               *
 *                                                                           *
 *  Alternatively, the contents of this file may be used under the terms of  *
 *  the GNU Lesser General Public License (the "LGPL"), in which case the    *
 *  provisions of LGPL are applicable instead of those above. If you wish to *
 *  allow use of your version of this file only under the  terms of the LGPL *
 *  and not to allow others to use your version of this file under the SPL,  *
 *  indicate your decision by deleting the provisions above and replace      *
 *  them with the notice and other provisions required by the LGPL.  If you  *
 *  do not delete the provisions above, a recipient may use your version of  *
 *  this file under either the SPL or the LGPL.                              *
 *                                                                           *
 *  biaoping.yin ([email protected])                                            *
 *                                                                           *
 *****************************************************************************/

package com.frameworkset.util;

import com.frameworkset.common.poolman.NestedSQLException;
import com.frameworkset.spi.assemble.BeanInstanceException;
import com.frameworkset.spi.assemble.CurrentlyInCreationException;
import org.frameworkset.util.BigFile;
import org.frameworkset.util.ClassUtil;
import org.frameworkset.util.ClassUtil.PropertieDescription;
import org.frameworkset.util.DataFormatUtil;
import org.frameworkset.util.MethodParameter;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;


import java.io.*;
import java.lang.reflect.Array;
import java.lang.reflect.Constructor;
import java.lang.reflect.InvocationTargetException;
import java.lang.reflect.Method;
import java.math.BigDecimal;
import java.math.BigInteger;
import java.net.URL;
import java.sql.Blob;
import java.sql.Clob;
import java.sql.Date;
import java.sql.SQLException;
import java.text.DateFormat;
import java.text.ParseException;
import java.text.SimpleDateFormat;
import java.util.*;

/**
 * @author biaoping.yin 改类充分使用java.lang.reflection中提供的功能,提供以下工具: 从对象中获取对应属性的值
 */
public class ValueObjectUtil {

	/**
	 * 基本数据类型,bboss定位如下:
	 * java定义的基本数据类型
	 * BigFile 大附件类型
	 * 枚举类型
	 * 日期类型
	 * 字符串类型
	 * 这些类型主要应用于mvc控制器方法参数的绑定过程中
	 */
	public static final Class[] baseTypes = {String.class,
		int.class ,Integer.class,
		long.class,Long.class,
		java.sql.Timestamp.class, Date.class,java.util.Date.class,
		boolean.class ,Boolean.class,
		BigFile.class,
		float.class ,Float.class,
		short.class ,Short.class,
		double.class,Double.class,
		char.class ,Character.class,

		byte.class ,Byte.class,
		BigDecimal.class,BigInteger.class};
	/**
	 * 用于序列化机制识别基础数据类型
	 */
	public static final Class[] basePrimaryTypes = {String.class,
		int.class ,
		long.class,
		boolean.class ,
//		BigFile.class,
		float.class ,
		short.class ,
		double.class,
		char.class ,
		byte.class ,
		Class.class,BigInteger.class,BigDecimal.class,
		java.sql.Timestamp.class, Date.class,java.util.Date.class
		};


	/**
	 * 用于序列化机制识别基础数据类型
	 */
	public static final Class[] simplePrimaryTypes = {String.class,
		int.class ,
		long.class,
		boolean.class ,
//		BigFile.class,
		float.class ,
		short.class ,
		double.class,
		char.class ,
		byte.class ,
		Class.class,
		java.sql.Timestamp.class, Date.class,java.util.Date.class, Locale.class
		};
	private static final Logger log = LoggerFactory.getLogger(ValueObjectUtil.class);

//	private static final SimpleDateFormat format = new SimpleDateFormat(
//			"yyyy-MM-dd HH:mm:ss");
	/**
	 * 缓存所有的日期格式
	 */
//	private static final Map dataformats = new HashMap();

//	/**
//	 * Description:获取对象obj的property属性值
//	 *
//	 * @param obj
//	 * @param property
//	 * @return Object
//	 */
//	public static Object getValue(Object obj, String property) {
//		return getValue(obj, property);
//	}

	/**
	 * Description:获取对象obj的property属性值,params为参数数组
	 *
	 * @param obj
	 * @param property

	 * @return Object
	 */
	public static Object getValue(Object obj, String property) {
		if (obj == null || property == null || property.trim().length() == 0)
			return null;
		Class clazz = obj.getClass();
		try {

			PropertieDescription pd = ClassUtil.getPropertyDescriptor(clazz, property);
			if(pd != null)
				return pd.getValue(obj);
			else
			{
				if(log.isDebugEnabled())
					log.debug(new StringBuilder().append("类").append(clazz.getCanonicalName()).append("没有定义属性").append( property ).toString());
			}


		} catch (Exception e) {
			if(log.isDebugEnabled())
				log.debug(new StringBuilder().append("获取类").append(clazz.getCanonicalName()).append("属性[") .append( property ).append( "]值异常:").toString(),e);
		}

		return null;
	}
	/**
	 * Description:获取对象obj的property属性值,params为参数数组
	 *
	 * @param obj
	 * @param property
	 * @return Object
	 */
	public static Object getValueOrSize(Object obj, String property) {
		boolean issize = false;


			if(property.startsWith("size:"))
			{
				issize = true;
				property = property.substring(5);
			}
			Object value =  getValue(  obj,   property);
			if(issize)
			{
				return length(value);
			}
			else
			{
				return value;
			}

	}

	public static int length(Object _actualValue)
	{
		if(_actualValue == null)
			return 0;
		else
		{
			if(_actualValue instanceof Collection)
			{
				return ((Collection)_actualValue).size();
			}
			else if(_actualValue instanceof Map)
			{
				return ((Map)_actualValue).size();
			}
			else if(_actualValue.getClass().isArray())
			{
				return Array.getLength(_actualValue);
			}
			else if(_actualValue instanceof String)
			{
				return ((String)_actualValue).length();
			}
			else if(_actualValue instanceof ListInfo)
			{
				return ((ListInfo)_actualValue).getSize();
			}
			else //评估对象长度
			{
				throw new IllegalArgumentException("无法计算类型为"+_actualValue.getClass().getName()+"的对象长度length。");
			}

		}
	}

	public static Object getValue(Object obj, String property,Object[] params) {
		if (obj == null || property == null || property.trim().length() == 0)
			return null;
		Class clazz = obj.getClass();
		try {
			if(params == null || params.length == 0)
			{
				PropertieDescription pd = ClassUtil.getPropertyDescriptor(clazz, property);
				if(pd != null)
					return pd.getValue(obj);
				else
				{
					if(log.isDebugEnabled())
						log.debug(new StringBuilder().append("类").append(clazz.getCanonicalName()).append("没有定义属性").append( property ).toString());
				}

			}
//			else
//			{
//				Method method = getMethodByPropertyName(obj, property);
//				return getValueByMethod(obj, method, params);
//			}
		} catch (Exception e) {
			if(log.isDebugEnabled())
				log.debug(new StringBuilder().append("获取类").append(clazz.getCanonicalName()).append("属性[") .append( property ).append( "]值异常:").toString(),e);
		}
		// Object ret = getValueByMethodName(obj, getMethodName(property),
		// params);
		// if (ret == null)
		// {
		// // log.debug("Try to get Boolean attribute for property[" + property
		// // + "].");
		// ret = getValueByMethodName(obj, getBooleanMethodName(property),
		// params);
		// if (ret != null)
		// log.debug("Get Boolean property[" + property + "=" + ret + "].");
		// }

		// return ret;
		return null;
	}

	/**
	 * Description:根据方法名称获取, 在对象obj上调用改方法并且返回调用的返回值
	 *
	 * @param obj
	 * @param methodName
	 *            方法名称
	 * @param params
	 *            方法的参数
	 * @return Object
	 * @deprecated
	 */
	public static Object getValueByMethodName(Object obj, String methodName,
			Object[] params) {
		if (obj == null || methodName == null
				|| methodName.trim().length() == 0)
			return null;
		return getValueByMethodName(obj, methodName, params, null);
	}

//	/*
//	 *
//	 */
//	@Deprecated
//	public static Method getMethodByPropertyName(Object obj,
//			String propertyName, Class[] paramsTtype) throws Exception {
//		String name = getMethodName(propertyName);
//		Method method = null;
//		try {
//			method = obj.getClass().getMethod(name, paramsTtype);
//		} catch (SecurityException e) {
//			name = getBooleanMethodName(propertyName);
//			method = obj.getClass().getMethod(name, paramsTtype);
//		} catch (NoSuchMethodException e) {
//			name = getBooleanMethodName(propertyName);
//			method = obj.getClass().getMethod(name, paramsTtype);
//		} catch (Exception e) {
//			name = getBooleanMethodName(propertyName);
//			method = obj.getClass().getMethod(name, paramsTtype);
//		}
//		return method;
//
//	}


	public static Method getMethodByPropertyName(Object obj,
			String propertyName) throws Exception {
//		String name = getMethodName(propertyName);
		Method method = null;
		try {
//			method = obj.getClass().getMethod(name, paramsTtype);
			PropertieDescription pd = ClassUtil.getPropertyDescriptor(obj.getClass(), propertyName);
			if(pd != null)
				method = pd.getReadMethod();

		} catch (SecurityException e) {
//			String name = getBooleanMethodName(propertyName);
//			method = obj.getClass().getMethod(name, null);
		}  catch (Exception e) {
//			String name = getBooleanMethodName(propertyName);
//			method = obj.getClass().getMethod(name, null);
		}
		if(method == null)
		{
			String name = getBooleanMethodName(propertyName);
//			method = obj.getClass().getMethod(name, null);
			method = ClassUtil.getDeclaredMethod(obj.getClass(),name);
			if(method == null)
				 throw new NoSuchMethodException(obj.getClass().getName() + "." + name );
		}
		return method;

	}

	/**
	 * Description:根据方法名称获取, 在对象obj上调用改方法并且返回调用的返回值
	 *
	 * @param obj
	 * @param methodName
	 *            方法名称
	 * @param params
	 *            方法的参数
	 * @param paramsTtype
	 *            方法的参数类型
	 * @deprecated
	 * @return Object
	 */
	public static Object getValueByMethodName(Object obj, String methodName,
			Object[] params, Class[] paramsTtype) {
		if (obj == null || methodName == null
				|| methodName.trim().length() == 0)
			return null;
		try {
			if(paramsTtype == null || paramsTtype.length == 0)
			{
				Method method = ClassUtil.getDeclaredMethod(obj.getClass(),methodName);
				if (method != null)
					return method.invoke(obj, params);
			}
			else
			{
				Method method = obj.getClass().getMethod(methodName, paramsTtype);
				if (method != null)
					return method.invoke(obj, params);
			}
		} catch (Exception e) {
			// e.printStackTrace();
			log.info("NoSuchMethodException:" + e.getMessage());
		}
		return null;

	}

	/**
	 * Description:根据方法名称获取, 在对象obj上调用改方法并且返回调用的返回值
	 *
	 * @param obj
	 * @param method
	 *            方法名称
	 * @param params
	 *            方法的参数

	 * @return Object
	 */
	public static Object getValueByMethod(Object obj, Method method,
			Object[] params) {
		if (obj == null || method == null)
			return null;
		try {
			// Method method = obj.getClass().getMethod(methodName,
			// paramsTtype);
			// if (method != null)
			return method.invoke(obj, params);
		} catch (Exception e) {
			// e.printStackTrace();
			log.info("Invoker method[" + method.getName() + "] on "
					+ obj.getClass().getCanonicalName() + " failed:"
					+ e.getMessage());
		}
		return null;

	}

	/**
	 * Description:实现在对象调用method并为该方法传入参数数组params
	 *
	 * @param obj
	 *            对象
	 * @param method
	 *            待调用的方法
	 * @param params
	 *            参数数组
	 * @return Object
	 * @throws Exception
	 *             Object
	 */
	public static Object invoke(Object obj, Method method, Object[] params)
			throws Exception {
		return method.invoke(obj, params);
	}
	/**
	 * Description:实现在对象调用method并为该方法传入参数数组params
	 *
	 * @param obj
	 *            对象
	 * @param method
	 *            待调用的方法
	 * @param params
	 *            参数数组
	 * @return Object
	 * @throws Exception
	 *             Object
	 */
	public static Object invoke(Object obj, String method, Object[] params)
			throws Exception {
		if(obj == null)
		{
			return null;
		}
		Class clazz = obj.getClass();
		Method _m = ClassUtil.getDeclaredMethod(clazz, method);
		return _m.invoke(obj, params);
	}

	/**
	 * 获取fieldName的getter方法名称
	 *
	 * @param fieldName
	 * @return String
	 */
	public static String getMethodName(String fieldName) {
		String ret = null;
		if (fieldName == null)
			return null;
		String letter = String.valueOf(fieldName.charAt(0));
		letter = letter.toUpperCase();
		ret = "get" + letter + fieldName.substring(1);
		// System.out.println("method name:" + ret);
		return ret;

	}

	public static String getBooleanMethodName(String fieldName) {
		String ret = null;
		if (fieldName == null)
			return null;
		String letter = String.valueOf(fieldName.charAt(0));
		letter = letter.toUpperCase();
		ret = "is" + letter + fieldName.substring(1);
		// System.out.println("method name:" + ret);
		return ret;

	}

	/**
	 * 获取fieldName的setter方法
	 *
	 * @param fieldName
	 * @return String
	 * @deprecated
	 */
	public static String getSetterMethodName(String fieldName) {
		String ret = null;
		if (fieldName == null)
			return null;
		String letter = String.valueOf(fieldName.charAt(0));
		letter = letter.toUpperCase();
		ret = "set" + letter + fieldName.substring(1);
		// System.out.println("method name:" + ret);
		return ret;

	}

	// public final static boolean isSameType(Class type, Class toType)
	// {
	// if(toType == Object.class)
	// return true;
	//
	// else if(type == toType)
	// return true;
	// else if(toType.isAssignableFrom(type))//检查toType是不是type的父类或者是type所实现的接口
	// {
	// return true;
	// }
	// else
	// if(type.isAssignableFrom(toType))//检查type是不是toType的父类或者是拖油瓶type所实现的接口
	// {
	// if(type.getName().equals(toType.getName()))
	// return true;
	// }
	//
	// else if((type == int.class && toType == Integer.class) ||
	// type == Integer.class && toType == int.class)
	// {
	// return true;
	// }
	// else if((type == short.class && toType == Short.class) ||
	// type == Short.class && toType == short.class)
	// {
	// return true;
	// }
	// else if((type == long.class && toType == Long.class) ||
	// type == Long.class && toType == long.class)
	// {
	// return true;
	// }
	// else if((type == double.class && toType == Double.class) ||
	// type == Double.class && toType == double.class)
	// {
	// return true;
	// }
	// else if((type == float.class && toType == Float.class) ||
	// type == Float.class && toType == float.class)
	// {
	// return true;
	// }
	// else if((type == char.class && toType == Character.class) ||
	// type == Character.class && toType == char.class)
	// {
	// return true;
	// }
	// return false;
	//
	//
	// }

	/**
	 *
	 * @param types
	 *            构造函数的参数类型
	 * @param params
	 *            外部传入的形式参数类型
	 * @return
	 */
	public static boolean isSameTypes(Class[] types, Class[] params,
			Object[] paramArgs) {

		if (types.length != params.length)
			return false;
		for (int i = 0; i < params.length; i++) {

			// if(!ValueObjectUtil.isSameType(type, toType))
			if (!isSameType(params[i], types[i], paramArgs[i])) {
				return false;
			}

		}
		return true;
	}

	public final static boolean isSameType(Class type, Class toType,
			Object value) {
		if (toType == Object.class)
			return true;

		else if (type == toType)
			return true;
		else if (toType.isAssignableFrom(type))// 检查toType是不是type的父类或者是type所实现的接口
		{
			return true;
		} else if (type.isAssignableFrom(toType))// 检查type是不是toType的父类或者是拖油瓶toType所实现的接口
		{
			try {
				toType.cast(value);
				return true;
			} catch (Exception e) {
				return false;
			}
			// if(type.getName().equals(toType.getName()))
			// return true;
		}
	 else if ((type == boolean.class && toType == Boolean.class)
				|| type == Boolean.class && toType == boolean.class) {
			return true;
		}
		else if ((type == int.class && toType == Integer.class)
				|| type == Integer.class && toType == int.class) {
			return true;
		} else if ((type == short.class && toType == Short.class)
				|| type == Short.class && toType == short.class) {
			return true;
		} else if ((type == long.class && toType == Long.class)
				|| type == Long.class && toType == long.class) {
			return true;
		} else if ((type == double.class && toType == Double.class)
				|| type == Double.class && toType == double.class) {
			return true;
		} else if ((type == float.class && toType == Float.class)
				|| type == Float.class && toType == float.class) {
			return true;
		} else if ((type == char.class && toType == Character.class)
				|| type == Character.class && toType == char.class) {
			return true;
		}
		return false;

	}

	/**
	 * 通过属性编辑器来转换属性值
	 *
	 * @param obj
	 * @param editor
	 * @return
	 * @throws NoSupportTypeCastException
	 * @throws NumberFormatException
	 * @throws IllegalArgumentException
	 */
	public final static Object typeCast(Object obj, EditorInf editor)
			throws NoSupportTypeCastException, NumberFormatException,
			IllegalArgumentException {

		return editor.getValueFromObject(obj);
	}
	public final static Object typeCast(Object obj, Class toType,String dateformat )
			throws NoSupportTypeCastException, NumberFormatException,
			IllegalArgumentException
			{
				return  typeCast( obj,   toType,  dateformat,(Locale )null);
			}

	/**
	 * 将obj对象从类型type转换到类型toType 支持字符串向其他基本类行转换: 支持的类型:
	 * int,char,short,double,float,long,boolean,byte
	 * java.sql.Date,java.util.Date, Integer Long Float Short Double Character
	 * Boolean Byte
	 *
	 * @param obj
	 * @param toType
	 * @return Object
	 * @throws ClassCastException
	 *             ,NumberFormatException,IllegalArgumentException
	 */
	public final static Object typeCast(Object obj, Class toType,String dateformat,Locale locale)
			throws NoSupportTypeCastException, NumberFormatException,
			IllegalArgumentException {
		if(toType == null)
			return obj;
		if (obj == null)
			return null;
		return typeCast(obj, obj.getClass(), toType,dateformat,  locale);
	}

	public final static Object typeCastWithDateformat(Object obj, Class toType,DateFormat dateformat)
			throws NoSupportTypeCastException, NumberFormatException,
			IllegalArgumentException {
		if (obj == null)
			return null;
		return typeCastWithDateformat(obj, obj.getClass(), toType,dateformat);
	}

	public final static Object typeCast(Object obj, Class toType)
	throws NoSupportTypeCastException, NumberFormatException,
	IllegalArgumentException{
		return typeCast( obj, toType,(String )null,(Locale )null);
	}
	public final static Object typeCast(Object obj, Class type, Class toType)
	throws NoSupportTypeCastException, NumberFormatException,
	IllegalArgumentException
	{
		return typeCast(obj, type, toType,null,(Locale )null);
	}

	public static byte[] getByteArrayFromBlob(Blob blob) throws SQLException
	{
		if(blob == null)
			return null;
		ByteArrayOutputStream out = null;
		InputStream in = null;

		try
		{
			out = new ByteArrayOutputStream();
			in =	blob.getBinaryStream();


			byte[] buf = new byte[1024];
			int i =0;

			while((i = in.read(buf)) > 0)
			{

//				System.out.println("i=" + i);

				out.write(buf,0,i);

			}

			return out.toByteArray();
		}
		catch(SQLException e)
		{
			throw e;
		}
		catch(Exception e)
		{
			throw new NestedSQLException(e);
		}
		finally
		{
			try
			{
				if(out != null)
				{
					out.close();
					out = null;
				}
			}
			catch(Exception e)
			{

			}

			try
			{
				if(in != null)
				{
					in.close();
					in = null;
				}
			}
			catch(Exception e)
			{

			}
		}


	}

	public static String getStringFromBlob(Blob blob) throws SQLException
	{
		if(blob == null)
			return null;
		OutputStream out = null;
		InputStream in = null;

		try
		{
			out = new ByteArrayOutputStream();
			in =	blob.getBinaryStream();


			byte[] buf = new byte[1024];
			int i =0;

			while((i = in.read(buf)) > 0)
			{

//				System.out.println("i=" + i);

				out.write(buf,0,i);

			}

			return out.toString();
		}
		catch(SQLException e)
		{
			throw e;
		}
		catch(Exception e)
		{
			throw new NestedSQLException(e);
		}
		finally
		{
			try
			{
				if(out != null)
				{
					out.close();
					out = null;
				}
			}
			catch(Exception e)
			{

			}

			try
			{
				if(in != null)
				{
					in.close();
					in = null;
				}
			}
			catch(Exception e)
			{

			}
		}


	}

	public static byte[] getByteArrayFromClob(Clob clob) throws SQLException
	{
		if(clob == null)
			return null;
		StringWriter w = null;

		Reader out = null;
		try
		{
			w = new StringWriter();
			out =	clob.getCharacterStream();
			char[] buf = new char[1024];
			int i =0;

			while((i = out.read(buf)) > 0)
			{
				w.write(buf,0,i);

			}
			String temp = w.toString();
			return temp.getBytes();
		}
		catch(SQLException e)
		{
			throw e;
		}
		catch(Exception e)
		{
			throw new NestedSQLException(e);
		}
		finally
		{
			try
			{
				if(out != null)
				{
					out.close();
					out = null;
				}
			}
			catch(Exception e)
			{

			}

			try
			{
				if(w != null)
				{
					w.close();
					w = null;
				}
			}
			catch(Exception e)
			{

			}
		}

	}

	public static String getStringFromClob(Clob clob) throws SQLException
	{
		if(clob == null)
			return null;
		StringWriter w = null;

		Reader out = null;
		try
		{
			w = new StringWriter();
			out =	clob.getCharacterStream();
			char[] buf = new char[1024];
			int i =0;

			while((i = out.read(buf)) > 0)
			{
				w.write(buf,0,i);

			}
			return w.toString();

		}
		catch(SQLException e)
		{
			throw e;
		}
		catch(Exception e)
		{
			throw new NestedSQLException(e);
		}
		finally
		{
			try
			{
				if(out != null)
				{
					out.close();
					out = null;
				}
			}
			catch(Exception e)
			{

			}

			try
			{
				if(w != null)
				{
					w.close();
					w = null;
				}
			}
			catch(Exception e)
			{

			}
		}

	}

	public static String getByteStringFromBlob(Blob blob) throws SQLException
	{
		if(blob == null)
			return null;
		ByteArrayOutputStream out = null;
		InputStream in = null;

		try
		{
			out = new ByteArrayOutputStream();
			in =	blob.getBinaryStream();


			byte[] buf = new byte[1024];
			int i =0;

			while((i = in.read(buf)) > 0)
			{

//				System.out.println("i=" + i);

				out.write(buf,0,i);

			}
			Base64 en = new Base64();
			return en.encode(out.toByteArray());
		}
		catch(SQLException e)
		{
			throw e;
		}
		catch(Exception e)
		{
			throw new NestedSQLException(e);
		}
		finally
		{
			try
			{
				if(out != null)
				{
					out.close();
					out = null;
				}
			}
			catch(Exception e)
			{

			}

			try
			{
				if(in != null)
				{
					in.close();
					in = null;
				}
			}
			catch(Exception e)
			{

			}
		}


	}
	/**
	 * 父类型向子类型转换
	 * @param obj
	 * @param toType
	 * @return
	 */
	public static Object cast(Object obj,Class toType)
	{
		try {
			if (!toType.isArray())
				return toType.cast(obj);
			else {
				int size = Array.getLength(obj);
				Class ctype = toType.getComponentType();
				Object ret = Array.newInstance(ctype, size);
				for (int i = 0; i < size; i++) {
					Array.set(ret, i, ctype.cast(Array.get(obj, i)));
				}
				return ret;
			}
		}
		catch (Exception e){
			throw new ValueCastException("类型转换异常,原值:"+String.valueOf(obj) + ",目标类型:"+toType.getCanonicalName(),e);
		}

	}
	public final static Object typeCast(Object obj, Class type, Class toType,String dateformat )
			throws NoSupportTypeCastException, NumberFormatException,
			IllegalArgumentException
			{
		return typeCast(  obj,   type,   toType,  dateformat,(Locale )null);
			}
	/**
	 * 将obj对象从类型type转换到类型toType 支持字符串向其他基本类行转换: 支持的类型:
	 * int,char,short,double,float,long,boolean,byte
	 * java.sql.Date,java.util.Date, Integer Long Float Short Double Character
	 * Boolean Byte
	 *
	 * @param obj
	 * @param type
	 * @param toType
	 * @return Object
	 * @throws ClassCastException
	 *             ,NumberFormatException,IllegalArgumentException
	 */
	public final static Object typeCast(Object obj, Class type, Class toType,String dateformat,Locale locale)
			throws NoSupportTypeCastException, NumberFormatException,
			IllegalArgumentException {
		if (obj == null)
			return null;
		if (isSameType(type, toType, obj))
			return obj;

		if (type.isAssignableFrom(toType)) // type是toType的父类,父类向子类转换的过程,这个转换过程是不安全的
		{
			// return shell(toType,obj);
			if (!java.util.Date.class.isAssignableFrom(type))
//				return toType.cast(obj);
				return cast(obj,toType);
		}

		if (type == byte[].class && toType == String.class) {
			return new String((byte[]) obj);
		} else if (type == String.class && toType == byte[].class) {
			return ((String) obj).getBytes();
		}
		else if (Blob.class.isAssignableFrom(type) ) {

			try
			{
				if( File.class.isAssignableFrom(toType))
				{
					File tmp = File.createTempFile(UUID.randomUUID().toString(),".tmp");
					getFileFromBlob((Blob)obj,tmp);
					return tmp;
				}
				else if( byte[].class.isAssignableFrom(toType))
				{
					return ValueObjectUtil.getByteArrayFromBlob((Blob)obj);
				}
				else
					return ValueObjectUtil.getStringFromBlob((Blob)obj);
			}
			catch (Exception e)
			{
				throw new IllegalArgumentException(new StringBuilder().append(
				"类型无法转换,不支持[").append(type.getName()).append("]向[")
				.append(toType.getName()).append("]转换").append(",value is  ").append(obj).toString());
			}


		}
		else if (Clob.class.isAssignableFrom(type) ) {

			try
			{
				if( File.class.isAssignableFrom(toType))
				{
					File tmp = File.createTempFile(UUID.randomUUID().toString(),".tmp");
					getFileFromClob((Clob)obj,tmp);
					return tmp;
				}
				else if( byte[].class.isAssignableFrom(toType))
				{
					return ValueObjectUtil.getByteArrayFromClob((Clob)obj);
				}
				else
					return ValueObjectUtil.getStringFromClob((Clob)obj);
			}
			catch (Exception e)
			{
				throw new IllegalArgumentException(new StringBuilder().append(
				"类型无法转换,不支持[").append(type.getName()).append("]向[")
				.append(toType.getName()).append("]转换").append(",value is ").append(obj).toString());
			}


		}

		else if (type == byte[].class && File.class.isAssignableFrom(toType)) {
			ByteArrayInputStream byteIn = null;
			FileOutputStream fileOut = null;
			if(!(obj instanceof byte[]))
			{
				Object[] object = (Object[]) obj;

				try {
					byteIn = new ByteArrayInputStream((byte[]) object[0]);
					fileOut = new FileOutputStream((File) object[1]);
					byte v[] = new byte[1024];

					int i = 0;

					while ((i = byteIn.read(v)) > 0) {
						fileOut.write(v, 0, i);

					}
					fileOut.flush();
					return object[1];
				} catch (FileNotFoundException e) {
					// TODO Auto-generated catch block
					e.printStackTrace();
				} catch (Exception e) {
					// TODO Auto-generated catch block
					e.printStackTrace();
				} finally {
					try {
						if (byteIn != null)
							byteIn.close();
					} catch (Exception e) {

					}
					try {
						if (fileOut != null)
							fileOut.close();
					} catch (Exception e) {

					}
				}
			}
			else
			{
				try {
					byteIn = new ByteArrayInputStream((byte[]) obj);
					File f = File.createTempFile(UUID.randomUUID().toString(), ".soa");
					fileOut = new FileOutputStream(f);
					byte v[] = new byte[1024];

					int i = 0;

					while ((i = byteIn.read(v)) > 0) {
						fileOut.write(v, 0, i);

					}
					fileOut.flush();
					return f;
				} catch (FileNotFoundException e) {
					// TODO Auto-generated catch block
					e.printStackTrace();
				} catch (Exception e) {
					// TODO Auto-generated catch block
					e.printStackTrace();
				} finally {
					try {
						if (byteIn != null)
							byteIn.close();
					} catch (Exception e) {

					}
					try {
						if (fileOut != null)
							fileOut.close();
					} catch (Exception e) {

					}
				}
			}
		} else if (List.class.isAssignableFrom(toType)) {

			if (!type.isArray()) {
				List valueto = new ArrayList();
				valueto.add(obj);
				return valueto;
			} else {
				if (type == String[].class) {
					List valueto = new ArrayList();
					for (String data : (String[]) obj)
						valueto.add(data);
					return valueto;
				}
			}

		}

		else if (Set.class.isAssignableFrom(toType)) {

			if (!type.isArray()) {
				Set valueto = new TreeSet();
				valueto.add(obj);
				return valueto;
			} else {
				if (type == String[].class) {
					Set valueto = new TreeSet();
					for (String data : (String[]) obj)
						valueto.add(data);
					return valueto;
				}

			}

		} else if (File.class.isAssignableFrom(toType)
				&& toType == byte[].class) {
			FileInputStream in = null;
			ByteArrayOutputStream out = null;
			try {
				int i = 0;
				in = new FileInputStream((File) obj);
				out = new ByteArrayOutputStream();
				byte v[] = new byte[1024];
				while ((i = in.read(v)) > 0) {
					out.write(v, 0, i);
				}
				return out.toByteArray();
			} catch (Exception e) {

			} finally {
				try {
					if (in != null)
						in.close();
				} catch (Exception e) {

				}
				try {
					if (out != null)
						out.close();
				} catch (Exception e) {

				}
			}

		} else if (type.isArray() && !toType.isArray()){
				//|| !type.isArray()
				//&& toType.isArray()) {
			// if (type.getName().startsWith("[")
			// && !toType.getName().startsWith("[")
			// || !type.getName().startsWith("[")
			// && toType.getName().startsWith("["))
			throw new IllegalArgumentException(new StringBuilder().append("类型无法转换,不支持[")
					.append(type.getName()).append("]向[").append(
							toType.getName()).append("]转换").append(",value is ").append(obj).toString());
		} else if (type == String.class && toType == Class.class) {
			try {
				return getClass((String) obj);
			} catch (ClassNotFoundException e) {
				throw new IllegalArgumentException(new StringBuilder().append(
						"类型无法转换,不支持[").append(type.getName()).append("]向[")
						.append(toType.getName()).append("]转换").toString(),e);
			}
		}
		Object arrayObj;

		/**
		 * 基本类型转换和基本类型之间相互转换
		 */
		if (!type.isArray() && !toType.isArray()) {
			arrayObj = basicTypeCast(obj, type, toType,dateformat,  locale);
		}

		/**
		 * 字符串数组向其他类型数组之间转换
		 * 数组和数组之间的转换
		 * 基础类型数据向数组转换
		 */
		else {

			arrayObj = arrayTypeCast(obj, type, toType,dateformat);
		}
		return arrayObj;
	}

	public final static Object typeCastWithDateformat(Object obj, Class type, Class toType,DateFormat dateformat)
			throws NoSupportTypeCastException, NumberFormatException,
			IllegalArgumentException {
		if (obj == null)
			return null;
		if (isSameType(type, toType, obj))
			return obj;

		if (type.isAssignableFrom(toType)) // type是toType的父类,父类向子类转换的过程,这个转换过程是不安全的
		{
			// return shell(toType,obj);
			if (!java.util.Date.class.isAssignableFrom(type))
//				return toType.cast(obj);
				return cast(obj,toType);
		}

		if (type == byte[].class && toType == String.class) {
			return new String((byte[]) obj);
		} else if (type == String.class && toType == byte[].class) {
			return ((String) obj).getBytes();
		}
		else if (Blob.class.isAssignableFrom(type) ) {

			try
			{
				if( File.class.isAssignableFrom(toType))
				{
					File tmp = File.createTempFile(UUID.randomUUID().toString(),".tmp");
					getFileFromBlob((Blob)obj,tmp);
					return tmp;
				}
				else if( byte[].class.isAssignableFrom(toType))
				{
					return ValueObjectUtil.getByteArrayFromBlob((Blob)obj);
				}
				else
					return ValueObjectUtil.getStringFromBlob((Blob)obj);
			}
			catch (Exception e)
			{
				throw new IllegalArgumentException(new StringBuilder().append(
				"类型无法转换,不支持[").append(type.getName()).append("]向[")
				.append(toType.getName()).append("]转换").append(",value is ").append(obj).toString());
			}


		}
		else if (Clob.class.isAssignableFrom(type) ) {

			try
			{
				if( File.class.isAssignableFrom(toType))
				{
					File tmp = File.createTempFile(UUID.randomUUID().toString(),".tmp");
					getFileFromClob((Clob)obj,tmp);
					return tmp;
				}
				else if( byte[].class.isAssignableFrom(toType))
				{
					return ValueObjectUtil.getByteArrayFromClob((Clob)obj);
				}
				else
					return ValueObjectUtil.getStringFromClob((Clob)obj);
			}
			catch (Exception e)
			{
				throw new IllegalArgumentException(new StringBuilder().append(
				"类型无法转换,不支持[").append(type.getName()).append("]向[")
				.append(toType.getName()).append("]转换").append(",value is ").append(obj).toString());
			}


		}

		else if (type == byte[].class && File.class.isAssignableFrom(toType)) {
			ByteArrayInputStream byteIn = null;
			FileOutputStream fileOut = null;
			if(!(obj instanceof byte[]))
			{
				Object[] object = (Object[]) obj;

				try {
					byteIn = new ByteArrayInputStream((byte[]) object[0]);
					fileOut = new FileOutputStream((File) object[1]);
					byte v[] = new byte[1024];

					int i = 0;

					while ((i = byteIn.read(v)) > 0) {
						fileOut.write(v, 0, i);

					}
					fileOut.flush();
					return object[1];
				} catch (FileNotFoundException e) {
					// TODO Auto-generated catch block
					e.printStackTrace();
				} catch (Exception e) {
					// TODO Auto-generated catch block
					e.printStackTrace();
				} finally {
					try {
						if (byteIn != null)
							byteIn.close();
					} catch (Exception e) {

					}
					try {
						if (fileOut != null)
							fileOut.close();
					} catch (Exception e) {

					}
				}
			}
			else
			{
				try {
					byteIn = new ByteArrayInputStream((byte[]) obj);
					File f = File.createTempFile(UUID.randomUUID().toString(), ".soa");
					fileOut = new FileOutputStream(f);
					byte v[] = new byte[1024];

					int i = 0;

					while ((i = byteIn.read(v)) > 0) {
						fileOut.write(v, 0, i);

					}
					fileOut.flush();
					return f;
				} catch (FileNotFoundException e) {
					// TODO Auto-generated catch block
					e.printStackTrace();
				} catch (Exception e) {
					// TODO Auto-generated catch block
					e.printStackTrace();
				} finally {
					try {
						if (byteIn != null)
							byteIn.close();
					} catch (Exception e) {

					}
					try {
						if (fileOut != null)
							fileOut.close();
					} catch (Exception e) {

					}
				}
			}
		} else if (List.class.isAssignableFrom(toType)) {

			if (!type.isArray()) {
				List valueto = new ArrayList();
				valueto.add(obj);
				return valueto;
			} else {
				if (type == String[].class) {
					List valueto = new ArrayList();
					for (String data : (String[]) obj)
						valueto.add(data);
					return valueto;
				}
			}

		}

		else if (Set.class.isAssignableFrom(toType)) {

			if (!type.isArray()) {
				Set valueto = new TreeSet();
				valueto.add(obj);
				return valueto;
			} else {
				if (type == String[].class) {
					Set valueto = new TreeSet();
					for (String data : (String[]) obj)
						valueto.add(data);
					return valueto;
				}

			}

		} else if (File.class.isAssignableFrom(toType)
				&& toType == byte[].class) {
			FileInputStream in = null;
			ByteArrayOutputStream out = null;
			try {
				int i = 0;
				in = new FileInputStream((File) obj);
				out = new ByteArrayOutputStream();
				byte v[] = new byte[1024];
				while ((i = in.read(v)) > 0) {
					out.write(v, 0, i);
				}
				return out.toByteArray();
			} catch (Exception e) {

			} finally {
				try {
					if (in != null)
						in.close();
				} catch (Exception e) {

				}
				try {
					if (out != null)
						out.close();
				} catch (Exception e) {

				}
			}

		} else if (type.isArray() && !toType.isArray()){
				//|| !type.isArray()
				//&& toType.isArray()) {
			// if (type.getName().startsWith("[")
			// && !toType.getName().startsWith("[")
			// || !type.getName().startsWith("[")
			// && toType.getName().startsWith("["))
			throw new IllegalArgumentException(new StringBuilder().append("类型无法转换,不支持[")
					.append(type.getName()).append("]向[").append(
							toType.getName()).append("]转换").append(",value is ").append(obj).toString());
		} else if (type == String.class && toType == Class.class) {
			try {
				return getClass((String) obj);
			} catch (ClassNotFoundException e) {
				throw new IllegalArgumentException(new StringBuilder().append(
						"类型无法转换,不支持[").append(type.getName()).append("]向[")
						.append(toType.getName()).append("]转换").toString(),e);
			}
		}
		Object arrayObj;

		/**
		 * 基本类型转换和基本类型之间相互转换
		 */
		if (!type.isArray() && !toType.isArray()) {
			arrayObj = basicTypeCastWithDateformat(obj, type, toType,dateformat);
		}

		/**
		 * 字符串数组向其他类型数组之间转换
		 * 数组和数组之间的转换
		 * 基础类型数据向数组转换
		 */
		else {

			arrayObj = arrayTypeCastWithDateformat(obj, type, toType,dateformat);
		}
		return arrayObj;
	}




	/**
	 * 通过BeanShell脚本来转换对象类型
	 *
	 * @param toType
	 * @param obj
	 * @return
	 */
	public static Object shell(Class toType, Object obj) {
		return toType.cast(obj);
//		Interpreter interpreter = new Interpreter();
//		String shell = toType.getName() + " ret = (" + toType.getName()
//				+ ")obj;return ret;";
//		try {
//			interpreter.set("obj", obj);
//			Object ret = interpreter.eval(shell);
//			return ret;
//		} catch (Exception e) {
//			throw new RuntimeException(e);
//		}
	}

	public final static Object basicTypeCast(Object obj,
											 Class toType) throws NoSupportTypeCastException,
			NumberFormatException
	{
		return  basicTypeCast( obj,obj.getClass(),
				toType,null,(Locale )null);
	}
	public final static Object basicTypeCast(Object obj, Class type,
			Class toType) throws NoSupportTypeCastException,
			NumberFormatException
			{
		return  basicTypeCast( obj, type,
				toType,null,(Locale )null);
			}

//	public static SimpleDateFormat getDateFormat(
//			String dateformat)
//	{
//		if(dateformat == null || dateformat.equals(""))
//			return format;
//		SimpleDateFormat f = dataformats.get(dateformat);
//		if(f != null)
//			return f;
//		f = new SimpleDateFormat(dateformat);
//		dataformats.put(dateformat, f);
//		return f;
//	}


	public static SimpleDateFormat getDefaultDateFormat(){
			return DataFormatUtil.getSimpleDateFormat("yyyy-MM-dd HH:mm:ss");
//			return new SimpleDateFormat(
//					"yyyy-MM-dd HH:mm:ss");
	}
	public static SimpleDateFormat getDateFormat(
			String dateformat,Locale locale)
	{
		if(dateformat == null || dateformat.equals(""))
			return  getDefaultDateFormat();
		SimpleDateFormat f = DataFormatUtil.getSimpleDateFormat(dateformat,  locale);
//		if(f != null)
//			return f;

//		dataformats.put(dateformat, f);
		return f;
	}

	public static Boolean toBoolean(Object obj)
	{
		if(obj == null)
			return new Boolean(false);
		if(obj instanceof Boolean)
		{
			return ((Boolean)obj);
		}
		else if(obj instanceof String)
		{
			String ret = obj.toString();
			if (ret.equals("1") || ret.equals("true")) {
				return new Boolean(true);
			} else if (ret.equals("0") || ret.equals("false")) {
				return new Boolean(false);
			}
			else
				return false;
		}
		else if(obj instanceof Integer)
		{
			return ((Integer)obj).intValue() > 0;
		}
		else if(obj instanceof Long)
		{
			return ((Long)obj).longValue() > 0;
		}
		else if(obj instanceof Double)
		{
			return ((Double)obj).doubleValue() > 0;
		}
		else if(obj instanceof Float)
		{
			return ((Float)obj).floatValue() > 0;
		}
		else if(obj instanceof Short)
		{
			return ((Short)obj).shortValue() > 0;
		}
		else if(obj instanceof BigInteger)
		{
			return ((BigInteger)obj).intValue() > 0;
		}
		else if(obj instanceof BigDecimal)
		{
			return ((BigDecimal)obj).floatValue() > 0;
		}

		return false;
	}
	public final static Object basicTypeCast(Object obj, Class type,
			Class toType,String dateformat ) throws NoSupportTypeCastException,
			NumberFormatException {
		return basicTypeCast(  obj,   type,
				  toType,  dateformat,(Locale )null);
	}
	/**
	 * Description:基本的数据类型转圜
	 *
	 * @param obj
	 * @param type
	 * @param toType
	 * @return Object
	 * @throws NoSupportTypeCastException
	 * @throws NumberFormatException
	 *
	 */
	public final static Object basicTypeCast(Object obj, Class type,
			Class toType,String dateformat,Locale locale) throws NoSupportTypeCastException,
			NumberFormatException {
		if (obj == null)
			return null;
		if (isSameType(type, toType, obj))
			return obj;

		if (type.isAssignableFrom(toType)) // type是toType的父类,父类向子类转换的过程,这个转换过程是不安全的
		{
			if (!java.util.Date.class.isAssignableFrom(type))
				return shell(toType, obj);
		}
		/**
		 * 如果obj的类型不是String型时直接抛异常, 不支持非字符串和字符串数组的类型转换
		 */
		// if (type != String.class)
		// throw new NoSupportTypeCastException(
		// new StringBuilder().append("不支持[")
		// .append(type)
		// .append("]向[")
		// .append(toType)
		// .append("]的转换")
		// .toString());
		/*******************************************
		 * 字符串向基本类型及其包装器转换 * 如果obj不是相应得数据格式,将抛出 * NumberFormatException *
		 ******************************************/
		if (toType == long.class || toType == Long.class) {
			if (ValueObjectUtil.isNumber(obj))
				return ((Number) obj).longValue();
			else if(java.util.Date.class.isAssignableFrom(type))
			{
				return ((java.util.Date)obj).getTime();
			}
			return Long.parseLong(obj.toString());
		}
		if (toType == int.class || toType == Integer.class) {
			if (ValueObjectUtil.isNumber(obj))
				return ((Number) obj).intValue();
			return Integer.parseInt(obj.toString());
		}
		if (toType == float.class || toType == Float.class) {
			if (ValueObjectUtil.isNumber(obj))
				return ((Number) obj).floatValue();
			return Float.parseFloat(obj.toString());
		}
		if (toType == short.class || toType == Short.class) {
			if (ValueObjectUtil.isNumber(obj))
				return ((Number) obj).shortValue();
			return Short.parseShort(obj.toString());
		}
		if (toType == double.class || toType == Double.class) {
			if (ValueObjectUtil.isNumber(obj))
				return ((Number) obj).doubleValue();
			return Double.parseDouble(obj.toString());
		}
		if (toType == char.class || toType == Character.class)
			return new Character(obj.toString().charAt(0));

		if (toType == boolean.class || toType == Boolean.class) {
//			String ret = obj.toString();
//			if (ret.equals("1") || ret.equals("true")) {
//				return new Boolean(true);
//			} else if (ret.equals("0") || ret.equals("false")) {
//				return new Boolean(false);
//			}
//			return new Boolean(ret);
			return toBoolean(obj);
		}

		if (toType == byte.class || toType == Byte.class)
			return new Byte(obj.toString());
		if(toType == BigDecimal.class)
		{
			return converObjToBigDecimal(obj);

		}
		if(toType == BigInteger.class)
		{
			return converObjToBigInteger(obj);

		}
		// 如果是字符串则直接返回obj.toString()
		if (toType == String.class) {
			if (obj instanceof java.util.Date)
			{

				if(!"".equals(obj))
					return getDateFormat(dateformat,  locale).format(obj);
				return null;
			}

			return obj.toString();
		}

		Object date = convertObjToDate( obj,toType,dateformat,locale);
		if(date != null)
			return date;

		if (type == String.class && toType == Class.class) {
			try {
				return getClass((String) obj);
			} catch (ClassNotFoundException e) {
				throw new IllegalArgumentException(new StringBuilder().append(
						"类型无法转换,不支持[").append(type.getName()).append("]向[")
						.append(toType.getName()).append("]转换").toString(),e);
			}
		}

		if (type == String.class && toType.isEnum())
		{

			try {
				return convertStringToEnum((String )obj,toType);
			} catch (SecurityException e) {
				throw new IllegalArgumentException(new StringBuilder().append(
				"类型无法转换,不支持[").append(type.getName()).append("]向枚举类型[")
				.append(toType.getName()).append("]转换,超出枚举值范围").append(",value is ").append(obj).toString());
			} catch (IllegalArgumentException e) {
				throw new IllegalArgumentException(new StringBuilder().append(
				"类型无法转换,不支持[").append(type.getName()).append("]向枚举类型[")
				.append(toType.getName()).append("]转换,超出枚举值范围").append(",value is ").append(obj).toString());
			} catch (NoSuchMethodException e) {
				throw new IllegalArgumentException(new StringBuilder().append(
				"类型无法转换,不支持[").append(type.getName()).append("]向枚举类型[")
				.append(toType.getName()).append("]转换,超出枚举值范围").append(",value is ").append(obj).toString());
			} catch (IllegalAccessException e) {
				throw new IllegalArgumentException(new StringBuilder().append(
				"类型无法转换,不支持[").append(type.getName()).append("]向枚举类型[")
				.append(toType.getName()).append("]转换,超出枚举值范围").append(",value is ").append(obj).toString());
			} catch (InvocationTargetException e) {
				throw new IllegalArgumentException(new StringBuilder().append(
				"类型无法转换,不支持[").append(type.getName()).append("]向枚举类型[")
				.append(toType.getName()).append("]转换,超出枚举值范围").append(",value is ").append(obj).toString());
			}
		}

		throw new NoSupportTypeCastException(new StringBuilder().append("不支持[").append(
				type).append("]向[").append(toType).append("]的转换").append(",value is ").append(obj).toString());

	}

	public final static Object basicTypeCastWithDateformat(Object obj, Class type,
			Class toType,DateFormat dateformat) throws NoSupportTypeCastException,
			NumberFormatException {
		if (obj == null)
			return null;
		if (isSameType(type, toType, obj))
			return obj;

		if (type.isAssignableFrom(toType)) // type是toType的父类,父类向子类转换的过程,这个转换过程是不安全的
		{
			if (!java.util.Date.class.isAssignableFrom(type))
				return shell(toType, obj);
		}
		/**
		 * 如果obj的类型不是String型时直接抛异常, 不支持非字符串和字符串数组的类型转换
		 */
		// if (type != String.class)
		// throw new NoSupportTypeCastException(
		// new StringBuilder("不支持[")
		// .append(type)
		// .append("]向[")
		// .append(toType)
		// .append("]的转换")
		// .toString());
		/*******************************************
		 * 字符串向基本类型及其包装器转换 * 如果obj不是相应得数据格式,将抛出 * NumberFormatException *
		 ******************************************/
		if (toType == long.class || toType == Long.class) {
			if (ValueObjectUtil.isNumber(obj))
				return ((Number) obj).longValue();
			else if(java.util.Date.class.isAssignableFrom(type))
			{
				return ((java.util.Date)obj).getTime();
			}
			return Long.parseLong(obj.toString());
		}
		if (toType == int.class || toType == Integer.class) {
			if (ValueObjectUtil.isNumber(obj))
				return ((Number) obj).intValue();
			return Integer.parseInt(obj.toString());
		}
		if (toType == float.class || toType == Float.class) {
			if (ValueObjectUtil.isNumber(obj))
				return ((Number) obj).floatValue();
			return Float.parseFloat(obj.toString());
		}
		if (toType == short.class || toType == Short.class) {
			if (ValueObjectUtil.isNumber(obj))
				return ((Number) obj).shortValue();
			return Short.parseShort(obj.toString());
		}
		if (toType == double.class || toType == Double.class) {
			if (ValueObjectUtil.isNumber(obj))
				return ((Number) obj).doubleValue();
			return Double.parseDouble(obj.toString());
		}
		if (toType == char.class || toType == Character.class)
			return new Character(obj.toString().charAt(0));

		if (toType == boolean.class || toType == Boolean.class) {
//			String ret = obj.toString();
//			if (ret.equals("1") || ret.equals("true")) {
//				return new Boolean(true);
//			} else if (ret.equals("0") || ret.equals("false")) {
//				return new Boolean(false);
//			}
//			return new Boolean(obj.toString());
			return toBoolean(obj);
		}

		if (toType == byte.class || toType == Byte.class)
			return new Byte(obj.toString());
		if(toType == BigDecimal.class)
		{
			return converObjToBigDecimal(obj);

		}
		// 如果是字符串则直接返回obj.toString()
		if (toType == String.class) {
			if (obj instanceof java.util.Date)
			{

				if(!"".equals(obj))
				{
					if(dateformat == null)
						dateformat = ValueObjectUtil.getDefaultDateFormat();
					return dateformat.format(obj);
				}
				return null;
			}

			return obj.toString();
		}

		Object date = convertObjToDateWithDateformat( obj,toType,dateformat);
		if(date != null)
			return date;

		if (type == String.class && toType == Class.class) {
			try {
				return getClass((String) obj);
			} catch (ClassNotFoundException e) {
				throw new IllegalArgumentException(new StringBuilder().append(
						"类型无法转换,不支持[").append(type.getName()).append("]向[")
						.append(toType.getName()).append("]转换").toString(),e);
			}
		}

		if (type == String.class && toType.isEnum())
		{

			try {
				return convertStringToEnum((String )obj,toType);
			} catch (SecurityException e) {
				throw new IllegalArgumentException(new StringBuilder().append(
				"类型无法转换,不支持[").append(type.getName()).append("]向枚举类型[")
				.append(toType.getName()).append("]转换,超出枚举值范围").append(",value is ").append(obj).toString());
			} catch (IllegalArgumentException e) {
				throw new IllegalArgumentException(new StringBuilder().append(
				"类型无法转换,不支持[").append(type.getName()).append("]向枚举类型[")
				.append(toType.getName()).append("]转换,超出枚举值范围").append(",value is ").append(obj).toString());
			} catch (NoSuchMethodException e) {
				throw new IllegalArgumentException(new StringBuilder().append(
				"类型无法转换,不支持[").append(type.getName()).append("]向枚举类型[")
				.append(toType.getName()).append("]转换,超出枚举值范围").append(",value is ").append(obj).toString());
			} catch (IllegalAccessException e) {
				throw new IllegalArgumentException(new StringBuilder().append(
				"类型无法转换,不支持[").append(type.getName()).append("]向枚举类型[")
				.append(toType.getName()).append("]转换,超出枚举值范围").append(",value is ").append(obj).toString());
			} catch (InvocationTargetException e) {
				throw new IllegalArgumentException(new StringBuilder().append(
				"类型无法转换,不支持[").append(type.getName()).append("]向枚举类型[")
				.append(toType.getName()).append("]转换,超出枚举值范围").append(",value is ").append(obj).toString());
			}
		}

		throw new NoSupportTypeCastException(new StringBuilder().append("不支持[").append(
				type).append("]向[").append(toType).append("]的转换").append(",value is ").append(obj).toString());

	}


	public static BigDecimal converObjToBigDecimal(Object obj)
	{
		if(obj.getClass() == long.class || obj.getClass() == Long.class)
			return BigDecimal.valueOf((Long)obj);
		if(obj.getClass() == short.class || obj.getClass() == Short.class)
			return BigDecimal.valueOf((Short)obj);
		if(obj.getClass() == int.class || obj.getClass() == Integer.class)
			return BigDecimal.valueOf((Integer)obj);
		if(obj.getClass() == double.class || obj.getClass() == Double.class)
			return BigDecimal.valueOf((Double)obj);
		if(obj.getClass() == float.class || obj.getClass() == Float.class)
			return BigDecimal.valueOf((Float)obj);
		return new BigDecimal(obj.toString());
	}
	public static BigInteger converObjToBigInteger(Object obj)
	{
		if(obj.getClass() == long.class || obj.getClass() == Long.class)
			return BigInteger.valueOf((Long)obj);
		if(obj.getClass() == short.class || obj.getClass() == Short.class)
			return BigInteger.valueOf((Short)obj);
		if(obj.getClass() == int.class || obj.getClass() == Integer.class)
			return BigInteger.valueOf((Integer)obj);
		if(obj.getClass() == double.class || obj.getClass() == Double.class)
			return BigInteger.valueOf(((Double)obj).longValue());
		if(obj.getClass() == float.class || obj.getClass() == Float.class)
			return BigInteger.valueOf(((Float)obj).longValue());
		return new BigInteger(obj.toString());
	}
	public static Object convertObjToDate(Object obj,Class toType,String dateformat )
	{
		return  convertObjToDate(  obj,  toType,  dateformat,(Locale )null);
	}
	public static Object convertObjToDate(Object obj,Class toType,String dateformat,Locale locale)
	{
		if(dateformat == null)
			return convertObjToDateWithDateformat(obj,toType,null);
		else
			return convertObjToDateWithDateformat(obj,toType,ValueObjectUtil.getDateFormat(dateformat,  locale));
	}
	public static Object convertObjToDateWithDateformat(Object obj,Class toType,DateFormat dateformat)
	{

		/**
		 * 字符串向java.util.Date和java.sql.Date 类型转换
		 */
		if (toType == java.util.Date.class) {

			if (java.util.Date.class.isAssignableFrom(obj.getClass()))
				return obj;
			if(obj.getClass() == long.class || obj.getClass() == Long.class)
			{
				return new java.util.Date((Long)obj);
			}
			String data_str = obj.toString();



			if(!"".equals(data_str))
			{
				if(dateformat == null)
				{
					try
					{

						long dl = Long.parseLong(data_str);
						return new java.util.Date(dl);
					}
					catch (Exception e1)
					{
						try
						{
							dateformat = ValueObjectUtil.getDefaultDateFormat();
							return new java.util.Date(dateformat.parse(data_str).getTime());
						} catch (ParseException e) {

							throw new IllegalArgumentException(new StringBuilder().append("Date format [").append(((SimpleDateFormat)dateformat).toPattern()).append("] can not format date : ").append(data_str).toString(),e);

						}
					}
				}
				else
				{
					try
					{
						return new java.util.Date(dateformat.parse(data_str).getTime());
					} catch (ParseException e) {
						try
						{

							long dl = Long.parseLong(data_str);
							return new java.util.Date(dl);
						}
						catch (Exception e1)
						{
							throw new IllegalArgumentException(new StringBuilder().append("Date format [").append(((SimpleDateFormat)dateformat).toPattern()).append("] can not format date : ").append(data_str).toString(),e);

						}

					}
				}
			}

			else
				return null;
//			return new java.util.Date(data_str);
		}

		if (toType == Date.class) {

			// if(obj instanceof java.sql.Date
			// || obj instanceof java.sql.Time
			// || obj instanceof java.sql.Timestamp)
			if (java.util.Date.class.isAssignableFrom(obj.getClass()))
				return new Date(((java.util.Date) obj).getTime());
			if(obj.getClass() == long.class || obj.getClass() == Long.class)
			{
				return new Date((Long)obj);
			}
			else if(obj.getClass() == int.class || obj.getClass() == Integer.class){
				return new Date(((Integer)obj).longValue());
			}
			String data_str = obj.toString();


				if(!"".equals(data_str))
				{
					if(dateformat == null)
					{
						try
						{

							long dl = Long.parseLong(data_str);
							return new Date(dl);
						}
						catch (Exception e1)
						{
							try
							{
								dateformat = ValueObjectUtil.getDefaultDateFormat();
								return new Date(dateformat.parse(data_str).getTime());
							} catch (ParseException e) {

								throw new IllegalArgumentException(new StringBuilder().append("Date format [").append(((SimpleDateFormat)dateformat).toPattern()).append("] can not format date : ").append(data_str).toString(),e);

							}
						}
					}
					else
					{
						try
						{
							return new Date(dateformat.parse(data_str).getTime());
						} catch (ParseException e) {
							try
							{

								long dl = Long.parseLong(data_str);
								return new Date(dl);
							}
							catch (Exception e1)
							{
								throw new IllegalArgumentException(new StringBuilder().append("Date format [").append(((SimpleDateFormat)dateformat).toPattern()).append("] can not format date : ").append(data_str).toString(),e);

							}

						}
					}
				}

				else
					return null;


			// java.util.Date(obj.toString()).getTime());


		}

		if (toType == java.sql.Timestamp.class) {

			// if(obj instanceof java.sql.Date
			// || obj instanceof java.sql.Time
			// || obj instanceof java.sql.Timestamp)
			if (java.util.Date.class.isAssignableFrom(obj.getClass()))
				return new java.sql.Timestamp(((java.util.Date) obj).getTime());
			if(obj.getClass() == long.class || obj.getClass() == Long.class)
			{
				return new java.sql.Timestamp((Long)obj);
			}
			String data_str = obj.toString();
			if(!"".equals(data_str))
			{
				if(dateformat == null)
				{
					try
					{

						long dl = Long.parseLong(data_str);
						return new java.sql.Timestamp(dl);
					}
					catch (Exception e1)
					{
						try
						{
							dateformat = ValueObjectUtil.getDefaultDateFormat();
							return new java.sql.Timestamp(dateformat.parse(data_str).getTime());
						} catch (ParseException e) {

							throw new IllegalArgumentException(new StringBuilder().append("Date format [").append(((SimpleDateFormat)dateformat).toPattern()).append("] can not format date : ").append(data_str).toString(),e);

						}
					}
				}
				else
				{
					try
					{
						return new java.sql.Timestamp(dateformat.parse(data_str).getTime());
					} catch (ParseException e) {
						try
						{

							long dl = Long.parseLong(data_str);
							return new java.sql.Timestamp(dl);
						}
						catch (Exception e1)
						{
							throw new IllegalArgumentException(new StringBuilder().append("Date format [").append(((SimpleDateFormat)dateformat).toPattern()).append("] can not format date : ").append(data_str).toString(),e);

						}

					}
				}
			}
			else
				return null;
			//java.sql.Timestamp date = new Timestamp(java.sql.Date.valueOf(data_str).getTime());// (new
			// java.util.Date(obj.toString()).getTime());

			//return date;
		}

		return null;
	}
	public static  T convertStringToEnum(String value,Class enumType) throws SecurityException, NoSuchMethodException,
				IllegalArgumentException, IllegalAccessException, InvocationTargetException
	{

		Method valueof = enumType.getMethod("valueOf", String.class);
		return (T)valueof.invoke(null, value);

	}

	/**
	 *
	 * @param 
	 * @param value
	 * @param enumType
	 * @param arrays
	 * @return
	 * @throws SecurityException
	 * @throws NoSuchMethodException
	 * @throws IllegalArgumentException
	 * @throws IllegalAccessException
	 * @throws InvocationTargetException
	 */
	public static  T[] convertStringToEnumArray(String value,Class enumType,T[] arrays) throws SecurityException, NoSuchMethodException,
	IllegalArgumentException, IllegalAccessException, InvocationTargetException
	{

		Method valueof = enumType.getMethod("valueOf", String.class);

		Array.set(arrays, 0, valueof.invoke(null, value));
		return arrays;

	}

	public static  T[] convertStringsToEnumArray(String[] value,Class enumType,T[] arrays) throws SecurityException, NoSuchMethodException,
	IllegalArgumentException, IllegalAccessException, InvocationTargetException
	{

		if(value == null)
			return null;
//		if(value.length == 0)

		int i = 0;
		Method valueof = enumType.getMethod("valueOf", String.class);
		for(String v:value)
		{
			Array.set(arrays, i, valueof.invoke(null, value[i]));
			i ++;
		}

		return arrays;

	}

	public static  T[] convertStringToEnumArray(String value,Class enumType) throws SecurityException, NoSuchMethodException,
	IllegalArgumentException, IllegalAccessException, InvocationTargetException
	{

		Method valueof = enumType.getMethod("valueOf", String.class);
		Object retvalue = Array.newInstance(enumType, 1);
		Array.set(retvalue, 0, valueof.invoke(null, value));
		return (T[])retvalue;

	}

	public static  T[] convertStringsToEnumArray(String[] value,Class enumType) throws SecurityException, NoSuchMethodException,
	IllegalArgumentException, IllegalAccessException, InvocationTargetException
	{

		if(value == null)
			return null;
//		if(value.length == 0)
		Object retvalue = Array.newInstance(enumType, value.length);
		int i = 0;
		Method valueof = enumType.getMethod("valueOf", String.class);
		for(String v:value)
		{
			Array.set(retvalue, i, valueof.invoke(null, value[i]));
			i ++;
		}

		return (T[])retvalue;
//		return temp_;

	}



	public final static Object arrayTypeCast(Object obj, Class type,
			Class toType) throws NoSupportTypeCastException,
			NumberFormatException {
		return arrayTypeCast(obj, type,
				toType,null);
	}
	public final static Object arrayTypeCast(Object obj, Class type,
			Class toType,String dateformat) throws NoSupportTypeCastException,
			NumberFormatException{
		SimpleDateFormat dateformat_ = null;
		if(dateformat != null)
			dateformat_ = DataFormatUtil.getSimpleDateFormat(dateformat);
		return arrayTypeCastWithDateformat(obj, type,
				toType,dateformat_);
	}
	/**
	 * 数组类型转换 支持字符串数组向一下类型数组得自动转换: int[] Integer[] long[] Long[] short[] Short[]
	 * double[] Double[] boolean[] Boolean[] char[] Character[] float[] Float[]
	 * byte[] Byte[] java.sql.Date[] java.util.Date[]
	 *
	 * @param obj
	 * @param type
	 * @param toType
	 * @return Object
	 * @throws NoSupportTypeCastException
	 * @throws NumberFormatException
	 */
	public final static Object arrayTypeCastWithDateformat(Object obj, Class type,
			Class toType,DateFormat dateformat) throws NoSupportTypeCastException,
			NumberFormatException {
		if (isSameType(type, toType, obj))
			return obj;
		// if (type != String[].class)
		// throw new NoSupportTypeCastException(
		// new StringBuilder("不支持[")
		// .append(type)
		// .append("]向[")
		// .append(toType)
		// .append("]的转换")
		// .toString());
		if(dateformat == null)
			dateformat = ValueObjectUtil.getDefaultDateFormat();
		if (toType == long[].class) {
			Class componentType = ValueObjectUtil.isNumberArray(obj);
			if (componentType == null) {
				if(java.util.Date.class.isAssignableFrom(type))
				{
					java.util.Date date = (java.util.Date)obj;
					return new long[]{date.getTime()};
				}
				else if(!isDateArray(obj))
				{
					String[] values = (String[]) obj;
					long[] ret = new long[values.length];
					for (int i = 0; i < values.length; i++) {
						ret[i] = Long.parseLong(values[i]);
					}
					return ret;
				}
				else
				{
					int len = Array.getLength(obj);
					long[] ret = new long[len];
					for(int i = 0;  i < len; i ++)
					{
						java.util.Date date = (java.util.Date)Array.get(obj, i);
						ret[i] = date.getTime();
					}
					return ret;

				}

			} else {
				return ValueObjectUtil.tolongArray(obj, componentType);

			}
		}
		if (toType == Long[].class) {

			Class componentType = ValueObjectUtil.isNumberArray(obj);
			if (componentType == null) {
				if(!isDateArray(obj))
				{
					String[] values = (String[]) obj;
					Long[] ret = new Long[values.length];
					for (int i = 0; i < values.length; i++) {
						ret[i] = new Long(values[i]);
					}

					return ret;
				}
				else
				{

					int len = Array.getLength(obj);
					Long[] ret = new Long[len];
					for(int i = 0;  i < len; i ++)
					{
						java.util.Date date = (java.util.Date)Array.get(obj, i);
						ret[i] = date.getTime();
					}
					return ret;
				}
			}
			else
			{
				return ValueObjectUtil.toLongArray(obj, componentType);
			}
		}

		if (toType == int[].class) {
			Class componentType = ValueObjectUtil.isNumberArray(obj);
			if (componentType == null) {
				String[] values = (String[]) obj;
				int[] ret = new int[values.length];
				for (int i = 0; i < values.length; i++) {
					ret[i] = Integer.parseInt(values[i]);
				}
				return ret;
			}
			else
			{
				return ValueObjectUtil.toIntArray(obj, componentType);
			}
		}
		if (toType == Integer[].class) {
			Class componentType = ValueObjectUtil.isNumberArray(obj);
			if (componentType == null) {
				String[] values = (String[]) obj;
				Integer[] ret = new Integer[values.length];
				for (int i = 0; i < values.length; i++) {
					ret[i] = new Integer(values[i]);
				}
				return ret;
			}
			else
			{
				return ValueObjectUtil.toIntegerArray(obj, componentType);
			}
		}
		if (toType == float[].class) {
			Class componentType = ValueObjectUtil.isNumberArray(obj);
			if (componentType == null) {
				String[] values = (String[]) obj;
				float[] ret = new float[values.length];
				for (int i = 0; i < values.length; i++) {
					ret[i] = Float.parseFloat(values[i]);
				}
				return ret;
			}
			else
			{
				return ValueObjectUtil.tofloatArray(obj, componentType);
			}
		}
		if (toType == Float[].class) {
			Class componentType = ValueObjectUtil.isNumberArray(obj);
			if (componentType == null) {
				String[] values = (String[]) obj;
				Float[] ret = new Float[values.length];
				for (int i = 0; i < values.length; i++) {
					ret[i] = new Float(values[i]);
				}
				return ret;
			}
			else
			{
				return ValueObjectUtil.toFloatArray(obj, componentType);
			}
		}
		if (toType == short[].class) {
			Class componentType = ValueObjectUtil.isNumberArray(obj);
			if (componentType == null) {
				String[] values = (String[]) obj;
				short[] ret = new short[values.length];
				for (int i = 0; i < values.length; i++) {
					ret[i] = Short.parseShort(values[i]);
				}
				return ret;
			}
			else
			{
				return ValueObjectUtil.toshortArray(obj, componentType);
			}
		}
		if (toType == Short[].class) {
			Class componentType = ValueObjectUtil.isNumberArray(obj);
			if (componentType == null) {
				String[] values = (String[]) obj;
				Short[] ret = new Short[values.length];
				for (int i = 0; i < values.length; i++) {
					ret[i] = new Short(values[i]);
				}
				return ret;
			}
			else
			{
				return ValueObjectUtil.toShortArray(obj, componentType);
			}
		}
		if (toType == double[].class) {
			Class componentType = ValueObjectUtil.isNumberArray(obj);
			if (componentType == null) {
				String[] values = (String[]) obj;
				double[] ret = new double[values.length];
				for (int i = 0; i < values.length; i++) {
					ret[i] = Double.parseDouble(values[i]);
				}
				return ret;
			}
			else
			{
				return ValueObjectUtil.todoubleArray(obj, componentType);
			}
		}
		if (toType == Double[].class) {
			Class componentType = ValueObjectUtil.isNumberArray(obj);
			if (componentType == null) {
				String[] values = (String[]) obj;
				Double[] ret = new Double[values.length];
				for (int i = 0; i < values.length; i++) {
					ret[i] = new Double(values[i]);
				}
				return ret;
			}
			else
			{
				return ValueObjectUtil.toDoubleArray(obj, componentType);
			}
		}

		if(toType == BigDecimal[].class)
		{

			return toBigDecimalArray(obj, null);

		}

		if(toType == BigInteger[].class)
		{

			return toBigIntegerArray(obj, null);

		}

		if (toType == char[].class) {
			String[] values = (String[]) obj;
			char[] ret = new char[values.length];
			for (int i = 0; i < values.length; i++) {
				ret[i] = values[i].charAt(0);
			}
			return ret;
		}
		if (toType == Character[].class) {
			String[] values = (String[]) obj;
			Character[] ret = new Character[values.length];
			for (int i = 0; i < values.length; i++) {
				ret[i] = new Character(values[i].charAt(0));
			}
			return ret;
		}

		if (toType == boolean[].class) {
			String[] values = (String[]) obj;
			boolean[] ret = new boolean[values.length];
			for (int i = 0; i < values.length; i++) {
				ret[i] = toBoolean(values[i]);//new Boolean(values[i]).booleanValue();
			}
			return ret;
		}
		if (toType == Boolean[].class) {
			String[] values = (String[]) obj;
			Boolean[] ret = new Boolean[values.length];
			for (int i = 0; i < values.length; i++) {
				ret[i] = toBoolean(values[i]);//new Boolean(values[i]);
			}
			return ret;
		}
		if (toType == byte[].class) {
			String[] values = (String[]) obj;
			byte[] ret = new byte[values.length];
			for (int i = 0; i < values.length; i++) {
				ret[i] = new Byte(values[i]).byteValue();
			}
			return ret;
		}
		if (toType == Byte[].class) {
			String[] values = (String[]) obj;
			Byte[] ret = new Byte[values.length];
			for (int i = 0; i < values.length; i++) {
				ret[i] = new Byte(values[i]);
			}
			return ret;
		}

		// 如果是字符串则直接返回obj.toString()
		if (toType == String[].class) {
			{
				if (obj.getClass() == java.util.Date[].class)
					return BaseSimpleStringUtil.dateArrayTOStringArray((Date[]) obj);
				String[] values = (String[]) obj;
				return values;
			}
			// short[] ret = new short[values.length];
			// for(int i = 0; i < values.length; i ++)
			// {
			// ret[i] = Short.parseShort(values[i]);
			// }
			// return ret;
		}
		/**
		 * 字符串向java.util.Date和java.sql.Date 类型转换
		 */
		Object dates = convertObjectToDateArrayWithDateFormat( obj,type,toType, dateformat);
		if(dates != null)
			return dates;
		/**
		 * 枚举数组类型处理转换
		 */
		if(toType.isArray() && toType.getComponentType().isEnum())
		{
			if(type == String.class )
			{
				try {
					Object value = convertStringToEnumArray((String )obj,toType.getComponentType());

					return value;
				} catch (SecurityException e) {
					throw new IllegalArgumentException(new StringBuilder().append(
					"类型无法转换,不支持[").append(type.getName()).append("]向枚举类型[")
					.append(toType.getName()).append("]转换,超出枚举值范围").append(",value is ").append(obj).toString());
				} catch (IllegalArgumentException e) {
					throw new IllegalArgumentException(new StringBuilder().append(
					"类型无法转换,不支持[").append(type.getName()).append("]向枚举类型[")
					.append(toType.getName()).append("]转换,超出枚举值范围").append(",value is ").append(obj).toString());
				} catch (NoSuchMethodException e) {
					throw new IllegalArgumentException(new StringBuilder().append(
					"类型无法转换,不支持[").append(type.getName()).append("]向枚举类型[")
					.append(toType.getName()).append("]转换,超出枚举值范围").append(",value is ").append(obj).toString());
				} catch (IllegalAccessException e) {
					throw new IllegalArgumentException(new StringBuilder().append(
					"类型无法转换,不支持[").append(type.getName()).append("]向枚举类型[")
					.append(toType.getName()).append("]转换,超出枚举值范围").append(",value is ").append(obj).toString());
				} catch (InvocationTargetException e) {
					throw new IllegalArgumentException(new StringBuilder().append(
					"类型无法转换,不支持[").append(type.getName()).append("]向枚举类型[")
					.append(toType.getName()).append("]转换,超出枚举值范围").append(",value is ").append(obj).toString());
				}
			}
			else if(type == String[].class )
			{
				try {
					Object value = convertStringsToEnumArray((String[] )obj,toType.getComponentType());

					return value;
				} catch (SecurityException e) {
					throw new IllegalArgumentException(new StringBuilder().append(
					"类型无法转换,不支持[").append(type.getName()).append("]向枚举类型[")
					.append(toType.getName()).append("]转换,超出枚举值范围").append(",value is ").append(obj).toString());
				} catch (IllegalArgumentException e) {
					throw new IllegalArgumentException(new StringBuilder().append(
					"类型无法转换,不支持[").append(type.getName()).append("]向枚举类型[")
					.append(toType.getName()).append("]转换,超出枚举值范围").append(",value is ").append(obj).toString());
				} catch (NoSuchMethodException e) {
					throw new IllegalArgumentException(new StringBuilder().append(
					"类型无法转换,不支持[").append(type.getName()).append("]向枚举类型[")
					.append(toType.getName()).append("]转换,超出枚举值范围").append(",value is ").append(obj).toString());
				} catch (IllegalAccessException e) {
					throw new IllegalArgumentException(new StringBuilder().append(
					"类型无法转换,不支持[").append(type.getName()).append("]向枚举类型[")
					.append(toType.getName()).append("]转换,超出枚举值范围").append(",value is ").append(obj).toString());
				} catch (InvocationTargetException e) {
					throw new IllegalArgumentException(new StringBuilder().append(
					"类型无法转换,不支持[").append(type.getName()).append("]向枚举类型[")
					.append(toType.getName()).append("]转换,超出枚举值范围").append(",value is ").append(obj).toString());
				}
			}

		}

		throw new NoSupportTypeCastException(new StringBuilder().append("不支持[").append(
				type).append("]向[").append(toType).append("]的转换").append(",value is ").append(obj).toString());

	}
	public static Object convertObjectToDateArray(Object obj,Class type,Class toType,String dateformat){
		return   convertObjectToDateArray(  obj,  type,  toType,  dateformat,null);
	}
	public static Object convertObjectToDateArray(Object obj,Class type,Class toType,String dateformat,Locale locale)
	{
		if(dateformat == null)
			return convertObjectToDateArrayWithDateFormat(obj,type,toType,ValueObjectUtil.getDefaultDateFormat());
		else
			return convertObjectToDateArrayWithDateFormat(obj,type,toType,ValueObjectUtil.getDateFormat(dateformat,  locale));
	}
	public static Object convertObjectToDateArrayWithDateFormat(Object obj,Class type,Class toType,DateFormat dateformat)
	{
		if(dateformat == null)
			dateformat = ValueObjectUtil.getDefaultDateFormat();
		if (toType == java.util.Date[].class) {
			if(type.isArray())
			{
				if(type == String[].class)
				{
					String[] values = (String[]) obj;
					return BaseSimpleStringUtil.stringArrayTODateArray(values,dateformat);
				}
				else
				{
					long[] values = (long[])obj;
					return BaseSimpleStringUtil.longArrayTODateArray(values,dateformat);
				}
			}
			else
			{
				if(type == String.class)
				{
					String[] values = new String[] {(String)obj};
					return BaseSimpleStringUtil.stringArrayTODateArray(values,dateformat);
				}
				else
				{
					long[] values = new long[] {((Long)obj).longValue()};
					return BaseSimpleStringUtil.longArrayTODateArray(values,dateformat);
				}
			}
		}
		if (toType == Date[].class) {
			if(type.isArray())
			{
				if(type == String[].class)
				{
					String[] values = (String[] )obj;
					return BaseSimpleStringUtil.stringArrayTOSQLDateArray(values,dateformat);
				}
				else
				{
					long[] values = (long[] )obj;

					return BaseSimpleStringUtil.longArrayTOSQLDateArray(values,dateformat);
				}
			}
			else
			{
				if(type == String.class)
				{
					String[] values = new String[] {(String)obj};
					return BaseSimpleStringUtil.stringArrayTOSQLDateArray(values,dateformat);
				}
				else
				{
					long[] values = new long[] {((Long)obj).longValue()};

					return BaseSimpleStringUtil.longArrayTOSQLDateArray(values,dateformat);
				}
			}

		}

		if (toType == java.sql.Timestamp[].class) {


			if(type.isArray())
			{
				if(type == String[].class)
				{
					String[] values = (String[] )obj;
					return BaseSimpleStringUtil.stringArrayTOTimestampArray(values,dateformat);
				}
				else
				{
					long[] values = (long[] )obj;

					return BaseSimpleStringUtil.longArrayTOTimestampArray(values,dateformat);
				}
			}
			else
			{
				if(type == String.class)
				{
					String[] values = new String[] {(String)obj};
					return BaseSimpleStringUtil.stringArrayTOTimestampArray(values,dateformat);
				}
				else
				{
					long[] values = new long[] {((Long)obj).longValue()};
					return BaseSimpleStringUtil.longArrayTOTimestampArray(values,dateformat);
				}
			}
		}
		return null;
	}

	public static void getFileFromString(String value, File outfile)
			throws SQLException {
		if(value == null)
			return;
		byte[] bytes = value.getBytes();
		getFileFromBytes(bytes, outfile);

	}

	public static void getFileFromBytes(byte[] bytes, File outfile)
			throws SQLException {
		if(bytes == null)
			return;
		FileOutputStream out = null;
		ByteArrayInputStream in = null;
		try {
			out = new FileOutputStream(outfile);
			byte v[] = (byte[]) bytes;
			in = new ByteArrayInputStream(v);
			byte b[] = new byte[1024];
			int i = 0;

			while ((i = in.read(b)) > 0) {
				out.write(b, 0, i);

			}

			out.flush();
		} catch (IOException e) {
			throw new NestedSQLException(e);
		} finally {
			try {
				if (out != null) {
					out.close();
					out = null;
				}
			} catch (Exception e) {

			}
			try {
				if (in != null) {
					in.close();
					in = null;
				}
			} catch (Exception e) {

			}
		}
	}

	public static void getFileFromClob(Clob value, File outfile)
			throws SQLException {
		if(value == null)
			return;
		Writer out = null;
		Reader stream = null;

		try {

			out = new FileWriter(outfile);
			Clob clob = (Clob) value;
			stream = clob.getCharacterStream();
			char[] buf = new char[1024];
			int i = 0;

			while ((i = stream.read(buf)) > 0) {
				out.write(buf, 0, i);

			}
			out.flush();
		} catch (IOException e) {
			throw new NestedSQLException(e);
		} finally {
			try {
				if (stream != null)
					stream.close();
			} catch (Exception e) {

			}
			try {
				if (out != null)
					out.close();
			} catch (Exception e) {

			}
		}
	}

	public static void getFileFromBlob(Blob value, File outfile)
			throws SQLException {
		if(value == null)
			return ;
		FileOutputStream out = null;
		InputStream in = null;
		try {
			out = new FileOutputStream(outfile);
			Blob blob = (Blob) value;
			byte v[] = new byte[1024];

			in = blob.getBinaryStream();
			int i = 0;

			while ((i = in.read(v)) > 0) {
				out.write(v, 0, i);

			}
			out.flush();
		} catch (IOException e) {
			throw new NestedSQLException(e);
		} finally {
			if (in != null) {
				try {
					in.close();
				} catch (IOException e) {
					// TODO Auto-generated catch block
					e.printStackTrace();
				}
				in = null;

			}
			if (out != null) {
				try {
					out.close();
				} catch (IOException e) {
					// TODO Auto-generated catch block
					e.printStackTrace();
				}
				out = null;
			}
		}
	}

	/**
	 * 根据参数值的类型修正先前定义的参数类型数组中对应的参数
	 * params中的类型与paramArgs对应位置相同类型的不修改,不相同的修改为paramArgs中相应的类型
	 *
	 * @param params
	 * @param paramArgs
	 * @return
	 */
	public static Class[] synParamTypes(Class[] params, Object[] paramArgs) {
		Class[] news = new Class[params.length];
		for (int i = 0; i < params.length; i++) {
			if (paramArgs[i] != null)
				news[i] = paramArgs[i].getClass();
			else {
				news[i] = params[i];
			}
		}
		return news;

	}

	public static Constructor getConstructor(Class clazz, Class[] params_,
			Object[] paramArgs) {
		return getConstructor(clazz, params_, paramArgs, false);

	}

	/**
	 * 根据参数类型params_,获取clazz的构造函数,paramArgs为参数的值,如果synTypes为true方法会
	 * 通过参数的值对参数类型进行校正 当符合params_类型的构造函数有多个时,返回最开始匹配上的构造函数,但是当synTypes为true时,
	 * 就会返回严格符合paramArgs值类型对应的构造函数 paramArgs值的类型也会作为获取构造函数的辅助条件,
	 *
	 * @param clazz
	 * @param params_
	 * @param paramArgs
	 * @param synTypes
	 * @return
	 */
	public static Constructor getConstructor(Class clazz, Class[] params_,
			Object[] paramArgs, boolean synTypes) {
		if (params_ == null || params_.length == 0) {
			return null;

		}
		Class[] params = null;
		if (synTypes)
			params = synParamTypes(params_, paramArgs);
		else
			params = params_;
		try {

			// Class[] params_ = this.getParamsTypes(params);
			Constructor constructor = null;
			// if (params_ != null)
			constructor = clazz.getConstructor(params);

			return constructor;
		} catch (NoSuchMethodException e) {
			Constructor[] constructors = clazz.getConstructors();
			if (constructors == null || constructors.length == 0)
				throw new CurrentlyInCreationException(
						"Inject constructor error: no construction define in the "
								+ clazz + ",请检查配置文件是否配置正确,参数个数是否正确.");
			int l = constructors.length;
			int size = params.length;
			Class[] types = null;
			Constructor fault_ = null;
			for (int i = 0; i < l; i++) {
				Constructor temp = constructors[i];
				types = temp.getParameterTypes();
				if (types != null && types.length == size) {
					if (fault_ == null)
						fault_ = temp;
					if (isSameTypes(types, params, paramArgs))
						return temp;
				}

			}
			if (fault_ != null)
				return fault_;
			throw new CurrentlyInCreationException(
					"Inject constructor error: Parameters with construction defined in the "
							+ clazz
							+ " is not matched with the config paramenters .请检查配置文件是否配置正确,参数个数是否正确.");

			// TODO Auto-generated catch block
			// throw new BeanInstanceException("Inject constructor error:"
			// +clazz.getName(),e);
		} catch (Exception e) {
			// TODO Auto-generated catch block
			throw new BeanInstanceException("Inject constructor error:"
					+ clazz.getName(), e);
		}

	}



	public static Object typeCast(Object value, Class requiredType,
			MethodParameter methodParam) throws NumberFormatException,
			IllegalArgumentException, NoSupportTypeCastException {
		// TODO Auto-generated method stub
		return ValueObjectUtil.typeCast(value, requiredType);
	}

	public static Object typeCast(Object oldValue, Object newValue,
			Class oldtype, Class toType, WrapperEditorInf editorInf) {
		// TODO Auto-generated method stub
		if (editorInf != null)
			return editorInf.getValueFromObject(newValue, oldValue);
		else {
			return ValueObjectUtil.typeCast(newValue, oldtype, toType);
		}
	}

	public static Object getDefaultValue(Class toType) {
		// 如果是字符串则直接返回obj.toString()
		if (toType == String.class) {
			return null;
		}
		if (toType == long.class )
			return 0L;
		if (toType == int.class )
			return 0;
		if (toType == float.class )
			return 0.0f;
		if (toType == double.class )
			return 0.0d;
		if (toType == boolean.class )

		{
			return false;
		}
		if (toType == short.class )
			return (short) 0;
		if (toType == char.class )
			return '0';

		if( toType == Long.class)
			return null;

		if( toType == Integer.class)
			return null;


		if( toType == Float.class)
			return null;

		if( toType == Short.class)
			return null;

		if( toType == Double.class)
			return null;

		if (toType == Character.class)
			return null;


		if(toType == Boolean.class)
			return null;

		if (toType == byte.class)
			return (byte) 0;

		if (toType == Byte.class)
			return new Byte((byte) 0);


		return null;
	}

	//
	// @org.junit.Test
	// public void doubletoint()
	// {
	// double number = 10.0;
	// int i = (int)number;
	// System.out.println(i);
	// }
//	@org.junit.Test
//	public void floatoint() {
//		float number = 10.1f;
//		int i = ((Number) number).intValue();
//		System.out.println(i);
//	}
//
//	@org.junit.Test
//	public void numberArray() {
//		double[] number = new double[] { 10.1 };
//		numberArray(number);
//	}
//
//	public void numberArray(Object tests) {
//		System.out.println(isNumberArray(tests));
//
//	}

	/**
	 * 对象比较功能,value1 > value2 返回1,value1 < value2 返回-1,value1 == value2 返回0
	 * 比较之前首先将value2转换为value1的类型
	 * 目前只支持数字和String,日期类型的比较,复杂类型不能使用改方法进行比较
	 */
	public static int typecompare(Object value1,Object value2)
	{
		if(value1 == null && value2 != null)
			return -1;
		if(value1 != null && value2 == null)
			return 1;
		if(value1 == null && value2 == null)
			return 0;
		Class vc1 = value1.getClass();

		try
		{
			if (value1 instanceof String && value2 instanceof String)
			{
				return ((String)value1).compareTo((String)value2);
			}
			else if (value1 instanceof String )
			{
				return ((String)value1).compareTo(String.valueOf(value2));
			}
			else if (vc1 == int.class || Integer.class.isAssignableFrom(vc1))
			{
				return intcompare(((Integer)value1).intValue(),value2);
			}
			else
			{
				if(value2 instanceof String)
				{
					if(((String)value2).equals(""))
						return -100;
				}
				if(vc1 == long.class
						|| Long.class.isAssignableFrom(vc1))
					return longCompare(((Long)value1).longValue(),value2);
				else if(vc1 == double.class
						|| Double.class.isAssignableFrom(vc1))
					return doubleCompare(((Double)value1).doubleValue(),value2);
				else if(vc1 == float.class
						|| Float.class.isAssignableFrom(vc1))
					return floatCompare(((Float)value1).floatValue(),value2);
				else if(java.util.Date.class.isAssignableFrom(vc1))
					return dateCompare((java.util.Date)value1,value2);
				else if(value1 instanceof java.util.Date && value2 instanceof java.util.Date)
					return dateCompare((java.util.Date)value1,(java.util.Date)value2);
				else if(vc1 == short.class
						|| Short.class.isAssignableFrom(vc1))
					return shortCompare(((Short)value1).shortValue(),value2);

			}
		}
		catch(Throwable e)
		{
			log.error("compare value1=" + value1 + ",value2=" + value2 + " failed,use default String compare rules instead.",e);
			return String.valueOf(value1).compareTo(String.valueOf(value2));
		}

		return String.valueOf(value1).compareTo(String.valueOf(value2));

	}


	public static int intcompare(int value1,Object value2)
	{
		Class vc2 = value2.getClass();
		if(String.class.isAssignableFrom(vc2))
		{
			int v2 = Integer.parseInt((String)value2);
			if(value1 == v2)
				return 0;
			else if(value1 > v2)
				return 1;
			else
				return -1;
		}
		else if(Integer.class.isAssignableFrom(vc2))
		{
			int v2 = ((Integer)value2).intValue();
			if(value1 == v2)
				return 0;
			else if(value1 > v2)
				return 1;
			else
				return -1;
		}
		else if(Long.class.isAssignableFrom(vc2))
		{
			long v2 = (Long)value2;
			if(value1 == v2)
				return 0;
			else if(value1 > v2)
				return 1;
			else
				return -1;
		}
		else if(Double.class.isAssignableFrom(vc2))
		{
			double v2 = ((Double)value2).doubleValue();
			if(value1 == v2)
				return 0;
			else if(value1 > v2)
				return 1;
			else
				return -1;
		}
		else if(Float.class.isAssignableFrom(vc2))
		{
			float v2 = ((Float)value2).floatValue();
			if(value1 == v2)
				return 0;
			else if(value1 > v2)
				return 1;
			else
				return -1;
		}
		else if(Short.class.isAssignableFrom(vc2))
		{
			short v2 = ((Short)value2).shortValue();
			if(value1 == v2)
				return 0;
			else if(value1 > v2)
				return 1;
			else
				return -1;
		}

		else if(java.util.Date.class.isAssignableFrom(vc2))
		{
			long v2 = ((java.util.Date)value2).getTime();
			if(value1 == v2)
				return 0;
			else if(value1 > v2)
				return 1;
			else
				return -1;
		}
		else
		{
			int v2 = Integer.parseInt((String)value2);
			if(value1 == v2)
				return 0;
			else if(value1 > v2)
				return 1;
			else
				return -1;
		}



	}

	public static int IntegerCompare(Integer value1,Object value2)
	{
		return intcompare(value1.intValue(),value2);
	}

	public static int longCompare(long value1,Object value2)
	{
		Class vc2 = value2.getClass();
		 if(String.class.isAssignableFrom(vc2))
		{
			long v2 = Long.parseLong((String)value2);
			if(value1 == v2)
				return 0;
			else if(value1 > v2)
				return 1;
			else
				return -1;
		}
		 else if(Integer.class.isAssignableFrom(vc2))
		{
			int v2 = ((Integer)value2).intValue();
			if(value1 == v2)
				return 0;
			else if(value1 > v2)
				return 1;
			else
				return -1;
		}
		else if(Long.class.isAssignableFrom(vc2))
		{
			long v2 = (Long)value2;
			if(value1 == v2)
				return 0;
			else if(value1 > v2)
				return 1;
			else
				return -1;
		}
		else if(Double.class.isAssignableFrom(vc2))
		{
			double v2 = ((Double)value2).doubleValue();
			if(value1 == v2)
				return 0;
			else if(value1 > v2)
				return 1;
			else
				return -1;
		}
		else if(Float.class.isAssignableFrom(vc2))
		{
			float v2 = ((Float)value2).floatValue();
			if(value1 == v2)
				return 0;
			else if(value1 > v2)
				return 1;
			else
				return -1;
		}
		else if(Short.class.isAssignableFrom(vc2))
		{
			short v2 = ((Short)value2).shortValue();
			if(value1 == v2)
				return 0;
			else if(value1 > v2)
				return 1;
			else
				return -1;
		}

		else if(java.util.Date.class.isAssignableFrom(vc2))
		{
			long v2 = ((java.util.Date)value2).getTime();
			if(value1 == v2)
				return 0;
			else if(value1 > v2)
				return 1;
			else
				return -1;
		}
		else
		{
			long v2 = Long.parseLong((String)value2);
			if(value1 == v2)
				return 0;
			else if(value1 > v2)
				return 1;
			else
				return -1;
		}
	}

	public static int LongCompare(Long value1,Object value2)
	{
		return longCompare(value1.longValue(),value2);
	}

	public static int doubleCompare(double value1,Object value2)
	{
		BigDecimal v1 = BigDecimal.valueOf(value1);
		BigDecimal v2 = null;
		Class vc2 = value2.getClass();
		if(java.util.Date.class.isAssignableFrom(vc2)) {
			v2 = BigDecimal.valueOf(((java.util.Date) value2).getTime());
		}
		else {
			v2 = new BigDecimal(String.valueOf(value2));
		}
		return v1.compareTo(v2);

//
//		Class vc2 = value2.getClass();
//		if(String.class.isAssignableFrom(vc2))
//		{
//			v2 = new BigDecimal((String)value2);
//			return v1.compareTo(v2);
////			if(value1 == v2)
////				return 0;
////			else if(value1 > v2)
////				return 1;
////			else
////				return -1;
//		}
//		else if(Integer.class.isAssignableFrom(vc2))
//		{
//			 v2 = new BigDecimal((Integer)value2);
//			return v1.compareTo(v2);
////			if(value1 == v2)
////				return 0;
////			else if(value1 > v2)
////				return 1;
////			else
////				return -1;
//		}
//		else if(Long.class.isAssignableFrom(vc2))
//		{
//			v2 = new BigDecimal((Long)value2);
//			return v1.compareTo(v2);
////			long v2 = (Long)value2;
////			if(value1 == v2)
////				return 0;
////			else if(value1 > v2)
////				return 1;
////			else
////				return -1;
//		}
//		else if(Double.class.isAssignableFrom(vc2))
//		{
//			double v2 = ((Double)value2).doubleValue();
//			if(value1 == v2)
//				return 0;
//			else if(value1 > v2)
//				return 1;
//			else
//				return -1;
//		}
//		else if(Float.class.isAssignableFrom(vc2))
//		{
//			float v2 = ((Float)value2).floatValue();
//			if(value1 == v2)
//				return 0;
//			else if(value1 > v2)
//				return 1;
//			else
//				return -1;
//		}
//		else if(Short.class.isAssignableFrom(vc2))
//		{
//			short v2 = ((Short)value2).shortValue();
//			if(value1 == v2)
//				return 0;
//			else if(value1 > v2)
//				return 1;
//			else
//				return -1;
//		}
//
//		else if(java.util.Date.class.isAssignableFrom(vc2))
//		{
//			long v2 = ((java.util.Date)value2).getTime();
//			if(value1 == v2)
//				return 0;
//			else if(value1 > v2)
//				return 1;
//			else
//				return -1;
//		}
//		else
//		{
//			double v2 = Double.parseDouble((String)value2);
//			if(value1 == v2)
//				return 0;
//			else if(value1 > v2)
//				return 1;
//			else
//				return -1;
//		}
	}

	public static int DoubleCompare(Double value1,Object value2)
	{
		return doubleCompare(value1.doubleValue(),value2);
	}

	public static int floatCompare(float value1,Object value2)
	{
		BigDecimal v1 = BigDecimal.valueOf(value1);
		BigDecimal v2 = null;
		Class vc2 = value2.getClass();
		if(java.util.Date.class.isAssignableFrom(vc2)) {
			v2 = BigDecimal.valueOf(((java.util.Date) value2).getTime());
		}
		else {
			v2 = new BigDecimal(String.valueOf(value2));
		}
		return v1.compareTo(v2);
//		Class vc2 = value2.getClass();
//		if(String.class.isAssignableFrom(vc2))
//		{
//			float v2 = Float.parseFloat(String.valueOf(value2));
//			if(value1 == v2)
//				return 0;
//			else if(value1 > v2)
//				return 1;
//			else
//				return -1;
//		}
//		else if(Integer.class.isAssignableFrom(vc2))
//		{
//			int v2 = ((Integer)value2).intValue();
//			if(value1 == v2)
//				return 0;
//			else if(value1 > v2)
//				return 1;
//			else
//				return -1;
//		}
//		else if(Long.class.isAssignableFrom(vc2))
//		{
//			long v2 = (Long)value2;
//			if(value1 == v2)
//				return 0;
//			else if(value1 > v2)
//				return 1;
//			else
//				return -1;
//		}
//		else if(Double.class.isAssignableFrom(vc2))
//		{
//			double v2 = ((Double)value2).doubleValue();
//			if(value1 == v2)
//				return 0;
//			else if(value1 > v2)
//				return 1;
//			else
//				return -1;
//		}
//		else if(Float.class.isAssignableFrom(vc2))
//		{
//			float v2 = ((Float)value2).floatValue();
//			if(value1 == v2)
//				return 0;
//			else if(value1 > v2)
//				return 1;
//			else
//				return -1;
//		}
//		else if(Short.class.isAssignableFrom(vc2))
//		{
//			short v2 = ((Short)value2).shortValue();
//			if(value1 == v2)
//				return 0;
//			else if(value1 > v2)
//				return 1;
//			else
//				return -1;
//		}
//
//		else if(java.util.Date.class.isAssignableFrom(vc2))
//		{
//			long v2 = ((java.util.Date)value2).getTime();
//			if(value1 == v2)
//				return 0;
//			else if(value1 > v2)
//				return 1;
//			else
//				return -1;
//		}
//		else
//		{
//			float v2 = Float.parseFloat(String.valueOf(value2));
//			if(value1 == v2)
//				return 0;
//			else if(value1 > v2)
//				return 1;
//			else
//				return -1;
//		}
	}

	public static int FloatCompare(Float value1,Object value2)
	{
		return floatCompare(value1.floatValue(),value2);
	}

	public static int shortCompare(short value1,Object value2)
	{
		Class vc2 = value2.getClass();
		if(String.class.isAssignableFrom(vc2))
		{
			short v2 = Short.parseShort(String.valueOf(value2));
			if(value1 == v2)
				return 0;
			else if(value1 > v2)
				return 1;
			else
				return -1;
		}
		else if(Integer.class.isAssignableFrom(vc2))
		{
			int v2 = ((Integer)value2).intValue();
			if(value1 == v2)
				return 0;
			else if(value1 > v2)
				return 1;
			else
				return -1;
		}
		else if(Long.class.isAssignableFrom(vc2))
		{
			long v2 = (Long)value2;
			if(value1 == v2)
				return 0;
			else if(value1 > v2)
				return 1;
			else
				return -1;
		}
		else if(Double.class.isAssignableFrom(vc2))
		{
			double v2 = ((Double)value2).doubleValue();
			if(value1 == v2)
				return 0;
			else if(value1 > v2)
				return 1;
			else
				return -1;
		}
		else if(Float.class.isAssignableFrom(vc2))
		{
			float v2 = ((Float)value2).floatValue();
			if(value1 == v2)
				return 0;
			else if(value1 > v2)
				return 1;
			else
				return -1;
		}
		else if(Short.class.isAssignableFrom(vc2))
		{
			short v2 = ((Short)value2).shortValue();
			if(value1 == v2)
				return 0;
			else if(value1 > v2)
				return 1;
			else
				return -1;
		}

		else if(java.util.Date.class.isAssignableFrom(vc2))
		{
			long v2 = ((java.util.Date)value2).getTime();
			if(value1 == v2)
				return 0;
			else if(value1 > v2)
				return 1;
			else
				return -1;
		}
		else
		{
			short v2 = Short.parseShort(String.valueOf(value2));
			if(value1 == v2)
				return 0;
			else if(value1 > v2)
				return 1;
			else
				return -1;
		}
	}

	public static int ShortCompare(Short value1,Object value2)
	{
		return shortCompare(value1.shortValue(),value2);
	}

	public static int dateCompare(java.util.Date value1,Object value2)
	{

		try {
			Class vc2 = value2.getClass();
			if(java.util.Date.class.isAssignableFrom(vc2))
			{
				java.util.Date v2 = ((java.util.Date)value2);
				return dateCompare(value1,v2);
			}
			else if(String.class.isAssignableFrom(vc2))
			{
				SimpleDateFormat format = DataFormatUtil.getSimpleDateFormat("yyyy-MM-dd HH:mm:ss");
				java.util.Date v2 = format.parse((String)value2);
				return dateCompare(value1,v2);
			}
			else if(Long.class.isAssignableFrom(vc2))
			{
				java.util.Date v2 = new java.util.Date(((Long)value2).longValue());
				return dateCompare(value1,v2);
			}
			if(Integer.class.isAssignableFrom(vc2))
			{

				java.util.Date v2 = new java.util.Date(((Integer)value2).intValue());
				return dateCompare(value1,v2);
			}

			else if(Double.class.isAssignableFrom(vc2))
			{

				java.util.Date v2 = new java.util.Date(((Double)value2).longValue());
				return dateCompare(value1,v2);
			}
			else if(Float.class.isAssignableFrom(vc2))
			{
				java.util.Date v2 = new java.util.Date(((Float)value2).longValue());
				return dateCompare(value1,v2);
			}
			else if(Short.class.isAssignableFrom(vc2))
			{
				java.util.Date v2 = new java.util.Date(((Short)value2).longValue());
				return dateCompare(value1,v2);
			}
			else
			{
				SimpleDateFormat format = DataFormatUtil.getSimpleDateFormat("yyyy-MM-dd HH:mm:ss");
				java.util.Date v2 = format.parse(String.valueOf(value2));
				return dateCompare(value1,v2);
			}


		} catch (Exception e) {
			return -1;
		}
	}

	public static int dateCompare(java.util.Date value1,java.util.Date value2)
	{
		long thisTime = value1.getTime();
        long anotherTime = value2.getTime();
        return (thisTime getClass(String type) throws ClassNotFoundException {
		if(type == null)
			return null;
		else if(type.equals("String") )
		{
			return String.class;
		}
		else if (type.equals("int"))
			return int.class;
		else if (type.equals("Integer"))
			return Integer.class;
		else if (type.equals("long"))
			return long.class;
		else if (type.equals("Long"))
			return Long.class;
		else if (type.equals("boolean"))
			return boolean.class;
		else if (type.equals("double"))
			return double.class;
		else if (type.equals("float"))
			return float.class;
		else if (type.equals("ArrayList"))
			return ArrayList.class;

		else if (type.equals("HashMap"))
			return HashMap.class;
		else if (type.equals("string") ||  type.equals("java.lang.String")
				|| type.equals("java.lang.string"))
			return String.class;


		else if (type.equals("short"))
			return short.class;
		else if (type.equals("char"))
			return char.class;


		else if (type.equals("Boolean"))
			return Boolean.class;
		else if (type.equals("Double"))
			return Double.class;
		else if (type.equals("Float"))
			return Float.class;
		else if (type.equals("Short"))
			return Short.class;
		else if (type.equals("Char") || type.equals("Character")
				|| type.equals("character"))

			return Character.class;
		else if (type.equals("bigint") )

			return BigInteger.class;
		else if (type.equals("bigdecimal") )

			return BigDecimal.class;
		else if( type.equals("String[]"))
		{
			return String[].class;
		}
		else if (type.equals("int[]"))
			return int[].class;
		else if (type.equals("Integer[]"))
			return Integer[].class;
		else if (type.equals("byte[]"))
			return byte[].class;
		else if (type.equals("string[]")  || type.equals("java.lang.String[]"))
			return String[].class;
		else if (type.equals("boolean[]"))
			return boolean[].class;
		else if (type.equals("double[]"))
			return double[].class;
		else if (type.equals("float[]"))
			return float[].class;
		else if (type.equals("short[]"))
			return short[].class;
		else if (type.equals("char[]"))
			return char[].class;
		else if (type.equals("long[]"))
			return long[].class;
		else if (type.equals("Long[]"))
			return Long[].class;

		else if (type.equals("Boolean[]"))
			return Boolean[].class;
		else if (type.equals("Double[]"))
			return Double[].class;
		else if (type.equals("Float[]"))
			return Float[].class;
		else if (type.equals("Short[]"))
			return Short[].class;
		else if (type.equals("bigint[]") )

			return BigInteger[].class;
		else if (type.equals("bigdecimal[]") )

			return BigDecimal[].class;
		else if (type.equals("Char[]") || type.equals("Character[]")
				|| type.equals("character[]"))
			return Character[].class;
		else if (type.equals("Class") || type.equals("class"))
			return Class.class;
		else if (type.equals("Class[]") || type.equals("class[]"))
			return Class[].class;
		else if (type.equals("byte"))
			return byte.class;
		else if (type.equals("TreeSet"))
			return TreeSet.class;
		else if(type.endsWith("[]"))
		{
			int len = type.length() - 2;
			int idx = type.indexOf("[");
			String subClass = type.substring(0,idx);
			String array = type.substring(idx);
			int count = 0;
			StringBuilder builder = new StringBuilder();


			for(int i = 0; i < array.length(); i ++)
			{
				char c = array.charAt(i);
				if(c == '[')
					builder.append("[");
			}
			builder.append("L").append(subClass).append(";");
			return Class.forName(builder.toString());


		}
		Class Type = Class.forName(type);
		return Type;
	}

	public static String byteArrayEncoder(byte[] contents)
	{
		Base64 en = new Base64();
		return en.encode(contents);
	}

	public static byte[] byteArrayDecoder(String contents) throws Exception
	{
		if(contents == null)
			return null;
		Base64 en = new Base64();
		return en.decode(contents);


	}

	public static String getFileContent(String configFile)
    {
    	try {
			return getFileContent(configFile,"UTF-8");
		} catch (Exception e) {
			return null;
		}
    }

//    public static String getFileContent(String configFile,String charset)
//    {
//
//
//        	try {
//				return getFileContent(getClassPathFile(configFile),charset);
//			} catch (Exception e) {
//				return null;
//			}
//
//    }
    private static ClassLoader getTCL() throws IllegalAccessException, InvocationTargetException {
        Method method = null;
        try {
            method = (Thread.class).getMethod("getContextClassLoader");
        } catch (NoSuchMethodException e) {
            return null;
        }
        return (ClassLoader)method.invoke(Thread.currentThread());
    }
    /**
     * InputStream reader = null;
					ByteArrayOutputStream swriter = null;
					OutputStream temp = null;
					try {
						reader = ValueObjectUtil
								.getInputStreamFromFile(PoolManConstants.XML_CONFIG_FILE_TEMPLATE);

						swriter = new ByteArrayOutputStream();
						temp = new BufferedOutputStream(swriter);

						int len = 0;
						byte[] buffer = new byte[1024];
						while ((len = reader.read(buffer)) > 0) {
							temp.write(buffer, 0, len);
						}
						temp.flush();
						pooltemplates = swriter.toString("UTF-8");

					} catch (Exception e) {
						// TODO Auto-generated catch block
						e.printStackTrace();
					} finally {
						if (reader != null)
							try {
								reader.close();
							} catch (IOException e) {
							}
						if (swriter != null)
							try {
								swriter.close();
							} catch (IOException e) {
							}
						if (temp != null)
							try {
								temp.close();
							} catch (IOException e) {
							}
					}
     * @param file
     * @param charSet
     * @return
     * @throws IOException
     */
    public static String getFileContent(File file,String charSet) throws IOException
    {
    	ByteArrayOutputStream swriter = null;
        OutputStream temp = null;
        InputStream reader = null;
        try
        {
        	reader = new FileInputStream(file);
        	swriter = new ByteArrayOutputStream();
        	temp = new BufferedOutputStream(swriter);

            int len = 0;
            byte[] buffer = new byte[1024];
            while ((len = reader.read(buffer)) > 0)
            {
            	temp.write(buffer, 0, len);
            }
            temp.flush();
            return swriter.toString(charSet);
        }
        catch (FileNotFoundException e)
        {
            e.printStackTrace();
            return "";
        }
        catch (IOException e)
        {
            e.printStackTrace();
            throw e;
        }
        finally
        {
            if (reader != null)
                try
                {
                    reader.close();
                }
                catch (IOException e)
                {
                }
            if (swriter != null)
                try
                {
                    swriter.close();
                }
                catch (IOException e)
                {
                }
            if (temp != null)
                try
                {
                	temp.close();
                }
                catch (IOException e)
                {
                }
        }
    }

    public static String getFileContent(String file,String charSet)
    {
    	ByteArrayOutputStream swriter = null;
        OutputStream temp = null;
        InputStream reader = null;
        try
        {
        	reader = getInputStreamFromFile(file);
        	swriter = new ByteArrayOutputStream();
        	temp = new BufferedOutputStream(swriter);

            int len = 0;
            byte[] buffer = new byte[1024];
            while ((len = reader.read(buffer)) > 0)
            {
            	temp.write(buffer, 0, len);
            }
            temp.flush();
            return swriter.toString(charSet);
        }
        catch (FileNotFoundException e)
        {
            e.printStackTrace();
            return "";
        }
        catch (IOException e)
        {
            e.printStackTrace();
            return "";
        } catch (Exception e) {
			// TODO Auto-generated catch block
        	return "";
		}
        finally
        {
            if (reader != null)
                try
                {
                    reader.close();
                }
                catch (IOException e)
                {
                }
            if (swriter != null)
                try
                {
                    swriter.close();
                }
                catch (IOException e)
                {
                }
            if (temp != null)
                try
                {
                	temp.close();
                }
                catch (IOException e)
                {
                }
        }
    }

    public static byte[] getBytesFileContent(String file)
    {
    	ByteArrayOutputStream swriter = null;
        OutputStream temp = null;
        InputStream reader = null;
        try
        {
        	reader = getInputStreamFromFile(file);
        	swriter = new ByteArrayOutputStream();
        	temp = new BufferedOutputStream(swriter);

            int len = 0;
            byte[] buffer = new byte[1024];
            while ((len = reader.read(buffer)) > 0)
            {
            	temp.write(buffer, 0, len);
            }
            temp.flush();
            return swriter.toByteArray();
        }
        catch (FileNotFoundException e)
        {
            e.printStackTrace();
            return null;
        }
        catch (IOException e)
        {
            e.printStackTrace();
            return null;
        } catch (Exception e) {
			// TODO Auto-generated catch block
        	return null;
		}
        finally
        {
            if (reader != null)
                try
                {
                    reader.close();
                }
                catch (IOException e)
                {
                }
            if (swriter != null)
                try
                {
                    swriter.close();
                }
                catch (IOException e)
                {
                }
            if (temp != null)
                try
                {
                	temp.close();
                }
                catch (IOException e)
                {
                }
        }
    }

    public static File getClassPathFile(String configFile) throws Exception
    {
    	String url = configFile;
        try {


	            URL confURL = ValueObjectUtil.class.getClassLoader().getResource(configFile);

	            if (confURL == null)

	                confURL = ValueObjectUtil.class.getClassLoader().getResource("/" + configFile);
	            else
	            {
//	            	String path = confURL.toString();
//	            	System.out.println(path);
	            }

	            if (confURL == null)
	                confURL = getTCL().getResource(configFile);
	            if (confURL == null)
	                confURL = getTCL().getResource("/" + configFile);
	            if (confURL == null)
	                confURL = ClassLoader.getSystemResource(configFile);
	            if (confURL == null)
	                confURL = ClassLoader.getSystemResource("/" + configFile);

	            if (confURL == null) {
	                url = System.getProperty("user.dir");
	                url += "/" + configFile;
	                File f = new File(url);
	            	if(f.exists())
	            		return f;
	            	return null;
	            } else {
	                url = confURL.getFile();
	                File f = new File(url);
	            	if(f.exists())
	            		return f;
	            	else
	            		f = new File(confURL.toString());
	            	return f;
	            }




        }
    	catch(Exception e)
    	{
    		throw e;
    	}
    }

    public static InputStream getInputStreamFromFile(String configFile) throws Exception
    {
    	String url = configFile;
        try {
            URL confURL = ValueObjectUtil.class.getClassLoader().getResource(configFile);
            if (confURL == null)
                confURL = ValueObjectUtil.class.getClassLoader().getResource("/" + configFile);

            if (confURL == null)
                confURL = getTCL().getResource(configFile);
            if (confURL == null)
                confURL = getTCL().getResource("/" + configFile);
            if (confURL == null)
                confURL = ClassLoader.getSystemResource(configFile);
            if (confURL == null)
                confURL = ClassLoader.getSystemResource("/" + configFile);

            if (confURL == null) {
                url = System.getProperty("user.dir");
                url += "/" + configFile;
                return new FileInputStream(new File(url));
            } else {
            	return confURL.openStream();
            }
        }
    	catch(Exception e)
    	{
    		  return new FileInputStream(configFile);
    	}
    }
	/**
	 * 判断类type是否是基础数据类型或者基础数据类型数组
	 * @param type
	 * @return
	 */
	public static boolean isSamplePrimaryType(Class type)
	{
		if(!type.isArray())
		{
			if(type.isEnum())
				return true;
			for(Class primaryType:ValueObjectUtil.baseTypes)
			{
				if(primaryType == type)
					return true;
			}
			return false;
		}
		else
		{
			return isPrimaryType(type.getComponentType());
		}

	}
    /**
     * 判断类type是否是基础数据类型或者基础数据类型数组
     * @param type
     * @return
     */
    public static boolean isPrimaryType(Class type)
    {
    	if(!type.isArray())
    	{
    		if(type.isEnum())
    			return true;
	    	for(Class primaryType:ValueObjectUtil.baseTypes)
	    	{
	    		if(primaryType.isAssignableFrom(type))
	    			return true;
	    	}
	    	return false;
    	}
    	else
    	{
    		return isPrimaryType(type.getComponentType());
    	}

    }

	/**
	 * 判断类type是否是数组
	 * @param type
	 * @return
	 */
	public static boolean isArrayType(Class type)
	{
		return type.isArray();


	}

	/**
	 * 判断类type是否是数字类型,或者数组的元素类型是否是数字类型
	 * @param type
	 * @return
	 */
	public static boolean isNumeric(Class type)
	{
		if(!type.isArray()) {
			return Integer.class.isAssignableFrom(type)
					|| int.class.isAssignableFrom(type)
					|| Long.class.isAssignableFrom(type)
					|| long.class.isAssignableFrom(type)
					|| Short.class.isAssignableFrom(type)
					|| short.class.isAssignableFrom(type)
					|| Double.class.isAssignableFrom(type)
					|| double.class.isAssignableFrom(type)
					|| float.class.isAssignableFrom(type)
					|| Float.class.isAssignableFrom(type)
					|| char.class.isAssignableFrom(type)
					|| BigDecimal.class.isAssignableFrom(type)
					|| BigInteger.class.isAssignableFrom(type)
					;
		}
		else{
			return isNumeric(type.getComponentType());
		}
	}


	public static Class getComponentType(Class type){
		if(!type.isArray())
			return type ;
		else{
			return getComponentType(type.getComponentType());
		}
	}

	/**
	 * 判断类type是否是List
	 * @param type
	 * @return
	 */
	public static boolean isListType(Class type)
	{
		return List.class.isAssignableFrom(type);


	}

	/**
	 * 判断类type是否是List
	 * @param type
	 * @return
	 */
	public static boolean isMapType(Class type)
	{
		return Map.class.isAssignableFrom(type);


	}

	/**
	 * 判断类type是否是List
	 * @param type
	 * @return
	 */
	public static boolean isEnumType(Class type)
	{
		return type.isEnum();


	}



	/**
     * 判断类type是否是基础数据类型
     * @param type
     * @return
     */
    public static boolean isBasePrimaryType(Class type)
    {
    	if(!type.isArray())
    	{
    		if(type.isEnum())
    			return true;
	    	for(Class primaryType:ValueObjectUtil.basePrimaryTypes)
	    	{
	    		if(primaryType.isAssignableFrom(type))
	    			return true;
	    	}
	    	return false;
    	}
    	return false;

    }
    /**
     * 判断类type是否是基础数据类型
     * @param type
     * @return
     */
    public static boolean isSimplePrimaryType(Class type)
    {
    	if(!type.isArray())
    	{

	    	for(Class primaryType:ValueObjectUtil.simplePrimaryTypes)
	    	{
	    		if(primaryType == type)
	    			return true;
	    	}
	    	if(type.isEnum())
    			return true;
	    	return false;
    	}
    	return false;

    }


    public static boolean isCollectionType(Class type)
    {
    	return Collection.class.isAssignableFrom(type);
    }



	/**
	 * @param values
	 * @param targetContainer
	 * @param elementType
	 */
	public static void typeCastCollection(String[] values,
			Collection targetContainer, Class elementType) {
		for(int i = 0 ; values != null && i < values.length;i ++)
		{
			String v = values[i];
			targetContainer.add(ValueObjectUtil.typeCast(v, elementType));
		}

	}
	public static void typeCastCollection(Object values,
			Collection targetContainer, Class elementType,String dateformat) {
		 typeCastCollection(  values,
				  targetContainer,   elementType,  dateformat,null);
	}
	/**
	 * @param values
	 * @param targetContainer
	 */
	public static void typeCastCollection(Object values,
			Collection targetContainer, Class elementType,String dateformat,Locale locale) {
		if(values == null)
			return;
		if(values.getClass().isArray())
		{
			for(int i = 0 ;  i < Array.getLength(values);i ++)
			{
				Object v = Array.get(values,i);
				targetContainer.add(ValueObjectUtil.typeCast(v, elementType,dateformat,  locale));
			}
		}
		else
		{
			targetContainer.add(ValueObjectUtil.typeCast(values, elementType));
		}

	}
	public static Collection createCollection(Class targetContainerType)
	{
		if (List.class.isAssignableFrom(targetContainerType)) {
			List valueto = new ArrayList();
			return valueto;
		}
		else //if (Set.class.isAssignableFrom(targetContainerType))
		{
			Set valueto = new TreeSet();
			return valueto;
		}
	}
	public static Object typeCastCollection(Object values,
			Class targetContainerType, Class elementType,String dateformat ) {
		return typeCastCollection(  values,
				  targetContainerType,   elementType,  dateformat,null);
	}
	/**
	 * @param values

	 */
	public static Object typeCastCollection(Object values,
			Class targetContainerType, Class elementType,String dateformat,Locale locale) {
		if(values == null)
			return null;
		Collection targetContainer = createCollection( targetContainerType);
		if(values.getClass().isArray())
		{
			for(int i = 0 ;  i < Array.getLength(values);i ++)
			{
				Object v = Array.get(values,i);
				targetContainer.add(ValueObjectUtil.typeCast(v, elementType,dateformat,  locale));
			}
		}
		else
		{
			targetContainer.add(ValueObjectUtil.typeCast(values, elementType,dateformat,  locale));
		}
		return targetContainer;
		
	}

	
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy