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

com.j2mvc.framework.dao.callback.InvokeObject Maven / Gradle / Ivy

Go to download

强烈建议使用J2mvc 2.1以后的版本。 version 2.1.01 1.优化路径跳转,Servlet和Filter方式的路径设置 2.优化内存销毁 3.更换JSON依赖包 4.优化接收方法RequestMethod,封装不同ContentType格式提交 封装JSON,XML数据提交模块 JSON请求示例 { "id":"JSON134851", "title":"JSON提交的标题", "price":65.1, "stock":100 } XML请求示例 <!DOCTYPE root [ <!ELEMENT root ANY> <!ATTLIST Product SSN ID #REQUIRED>]> <root> <Product SSN='id'>XMLID12354</Product> <Product SSN='title'>XML提交的标题 </Product> <Product SSN='price'>55 </Product> <Product SSN='stock'>32 </Product> </root> version 2.1.02 1.解决URL无后缀情况无法加载静态资源,解决无法渲染CSS文件。 version 2.1.03 1.移除com.j2mvc.StringUtils.getUtf8()方法调用 更改为getCharset() version 2.1.04 1.去除Servlet和Filter的全局变量销毁,只交给Listener处理。 version 2.1.05,2.1.06,2.1.07 1.完善POST提交的JSON数据 支持接收基础数据类型、任意对象类型、任意数组类型。 不支持接收参数为集合类型或Map类型,但可以定义为接收对象类型的元素。 version 2.1.05,2.1.06,2.1.07 1.修改连接池变量 version 2.1.09 增加上传功能,修改RequestMethod,ContentType设置方式 version 2.1.10,2.1.11 更改上传文件名格式为UUID格式,移除JSON映射类,更改接收多文件上传。 version 2.1.12 删除文件列有的空对象 version 2.1.13 增加配置文件目录/conf,加载上传功能配置/conf/upload.properties version 2.1.18 拦截器也能获取ActionBean version 2.1.20 添加上传文件只读权限 version 2.1.21 支持同时接收文件和文本数据 version 2.1.22 增加文件接收类型media version 2.1.23 删除upload类printJson方法

The newest version!
package com.j2mvc.framework.dao.callback;

import java.beans.IntrospectionException;
import java.beans.PropertyDescriptor;
import java.io.InputStream;
import java.io.UnsupportedEncodingException;
import java.lang.reflect.Field;
import java.lang.reflect.InvocationTargetException;
import java.lang.reflect.Method;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Time;
import java.util.Collection;
import java.util.Date;
import java.util.List;

import org.apache.log4j.Logger;
import com.j2mvc.framework.dao.DaoSupport;
import com.j2mvc.framework.mapping.Column;
import com.j2mvc.framework.mapping.DataSourceName;
import com.j2mvc.framework.mapping.Foreign;
import com.j2mvc.framework.mapping.Sql;
import com.j2mvc.framework.util.FieldUtil;


public class InvokeObject {

	static final Logger log = Logger.getLogger(InvokeObject.class);
	/**
	 * 写入字段数组值
	 * @param fields
	 * @param obj
	 * @param rs
	 */
	public static void invoke(List fields,Object obj,ResultSet rs,String dataSourceName){
		for(int i=0;i type = field.getType();	
		try {
			Object value = null;
			if(foreign!=null){
				// 外键对象之主键属性数据类型
				type = FieldUtil.getForeignKey(type).getType();
			}
			if(String.class.isAssignableFrom(type))
				value = rs.getString(column.name());				
			else if(Integer.class.isAssignableFrom(type) 
					|| Short.class.isAssignableFrom(type)
					|| short.class.isAssignableFrom(type)
					|| int.class.isAssignableFrom(type))
				value = rs.getInt(column.name());
			else if(Long.class.isAssignableFrom(type) 
					|| long.class.isAssignableFrom(type))
				value = rs.getLong(column.name());
			else if(Float.class.isAssignableFrom(type)
					|| float.class.isAssignableFrom(type))
				value = rs.getFloat(column.name());
			else if(Double.class.isAssignableFrom(type)
					|| double.class.isAssignableFrom(type))
				value = rs.getDouble(column.name());
			else if(Boolean.class.isAssignableFrom(type)
					|| boolean.class.isAssignableFrom(type))
				value = rs.getBoolean(column.name());
			else if(Time.class.isAssignableFrom(type))
				value = rs.getTime(column.name());
			else if(Date.class.isAssignableFrom(type)){
				value = rs.getDate(column.name());
			}else if(byte[].class.isAssignableFrom(type)){
				value = rs.getBytes(column.name());
			}else if(Collection.class.isAssignableFrom(type)
					|| String[].class.isAssignableFrom(type)){
				byte[] bytes = rs.getBytes(column.name());
				if(bytes!=null)
					value = StreamUtil.bytesToObject(bytes);
				if(value == null){
					try {
						value = new String(bytes,"UTF-8");
					} catch (UnsupportedEncodingException e) {
						// TODO Auto-generated catch block
						e.printStackTrace();
					}
				}
			}else if(InputStream.class.isAssignableFrom(type)){
				value = rs.getBinaryStream(column.name());
			}			
			if(foreign!=null){
				// 外键,字段为对象,获取类主键,并实例
				try {
					Class fieldClass =  field.getType();
					DataSourceName dsn = fieldClass.getAnnotation(DataSourceName.class);	
					DaoSupport daoSupport = null;
					if(dsn!=null){
						daoSupport = new DaoSupport(fieldClass,dsn.value());
					}else if(dataSourceName!=null && !dataSourceName.equals("")){
						daoSupport = new DaoSupport(fieldClass,dataSourceName);
					}else {
						daoSupport = new DaoSupport(fieldClass);
					}
					value = daoSupport.get(value);
				} catch (Exception e) {
					log.error(e.getMessage());
//					e.printStackTrace();
				}
			}else if(sql!=null){
				// 根据SQL语句查询值
				try {
					DaoSupport daoSupport = new DaoSupport(field.getType());
					value = daoSupport.get(sql.value());
				} catch (Exception e) {
					log.error(e.getMessage());
//					e.printStackTrace();
				}
			}
			// 执行写入操作
			PropertyDescriptor pd = new PropertyDescriptor(name, obj.getClass());
			Method wm = pd.getWriteMethod();
			if(value!=null)
				wm.invoke(obj, value);			
		} catch (IntrospectionException e) {
			e.printStackTrace();
		}catch (IllegalArgumentException e) {
			e.printStackTrace();
		}catch (IllegalAccessException e) {
			e.printStackTrace();
		}catch (InvocationTargetException e) {
			e.printStackTrace();
		}catch (SQLException e) {
			log.error(e.getMessage());
//			e.printStackTrace();
		} 
		
	}
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy