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

com.nervousync.utils.BeanUtils Maven / Gradle / Ivy

There is a newer version: 1.0.1
Show newest version
/*
 * Licensed to the Nervousync Studio (NSYC) under one or more
 * contributor license agreements.  See the NOTICE file distributed with
 * this work for additional information regarding copyright ownership.
 * The ASF licenses this file to You under the Apache License, Version 2.0
 * (the "License"); you may not use this file except in compliance with
 * the License.  You may obtain a copy of the License at
 *
 *      http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */
package com.nervousync.utils;

import java.io.IOException;
import java.util.Hashtable;

import net.sf.cglib.beans.BeanCopier;
import net.sf.cglib.core.Converter;

import com.nervousync.exceptions.beans.BeansException;

/**
 * @author Steven Wee	[email protected]
 * @version $Revision: 1.0 $ $Date: Jun 25, 2015 2:55:15 PM $
 */
public final class BeanUtils {

	private static Hashtable BEAN_COPIER_MAP = new Hashtable();
	
	private BeanUtils() {
		
	}
	
	/**
	 * Copy the property values of the given source bean into the target bean.
	 * 

Note: The source and target classes do not have to match or even be derived * from each other, as long as the properties match. Any bean properties that the * source bean exposes but the target bean does not will silently be ignored. *

This is just a convenience method. For more complex transfer needs, * consider using a full BeanWrapper. * @param orig the source bean * @param dest the target bean * @throws BeansException if the copying failed * @see BeanWrapper */ public static void copyProperties(Object orig, Object dest) throws BeansException { BeanUtils.copyProperties(orig, dest, null); } /** * Copy the property values of the given source bean into the target bean. *

Note: The source and target classes do not have to match or even be derived * from each other, as long as the properties match. Any bean properties that the * source bean exposes but the target bean does not will silently be ignored. *

This is just a convenience method. For more complex transfer needs, * consider using a full BeanWrapper. * @param orig the source bean * @param dest the target bean * @param converter converter instance * @throws BeansException if the copying failed * @see BeanWrapper */ public static void copyProperties(Object orig, Object dest, Converter converter) throws BeansException { BeanCopier beanCopier = null; try { String cacheKey = null; if (converter == null) { cacheKey = BeanUtils.generateKey(orig.getClass(), dest.getClass(), null); } else { cacheKey = BeanUtils.generateKey(orig.getClass(), dest.getClass(), converter.getClass()); } if (BeanUtils.BEAN_COPIER_MAP.containsKey(cacheKey)) { beanCopier = BeanUtils.BEAN_COPIER_MAP.get(cacheKey); } else { if (converter == null) { beanCopier = BeanCopier.create(orig.getClass(), dest.getClass(), false); } else { beanCopier = BeanCopier.create(orig.getClass(), dest.getClass(), true); } BeanUtils.BEAN_COPIER_MAP.put(cacheKey, beanCopier); } beanCopier.copy(orig, dest, converter); } catch (IOException e) { throw new BeansException("Copy properties error! ", e); } } private static String generateKey(Class origClass, Class destClass, Class converterClass) throws IOException { if (converterClass == null) { return SecurityUtils.MD5(origClass.getName() + "To" + destClass.getName()); } else { return SecurityUtils.MD5(origClass.getName() + "To" + destClass.getName() + "Converter:" + converterClass.getName()); } } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy