DTO与Entity相互转化

import java.lang.reflect.Method;
import java.util.concurrent.ConcurrentHashMap;


import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.cglib.beans.BeanCopier;


import com.jzd.popularfeelings.web.rest.LoginController;
public final class ConverterUtil {

private static final Logger logger = LoggerFactory.getLogger(LoginController.class);
// 使用多线程安全的Map来缓存BeanCopier,由于读操作远大于写,所以性能影响可以忽略
        public static ConcurrentHashMap<String, BeanCopier> beanCopierMap = new ConcurrentHashMap<String, BeanCopier>();
         
        /**
         * 通过cglib BeanCopier形式
         * @param source
         * @param target
         */
        public static void copyProperties(Object source, Object target) {
            String beanKey = generateKey(source.getClass(), target.getClass());
            BeanCopier copier = null;
            copier = BeanCopier.create(source.getClass(), target.getClass(), false);
            beanCopierMap.putIfAbsent(beanKey, copier);// putIfAbsent已经实现原子操作了。
            copier = beanCopierMap.get(beanKey);
            copier.copy(source, target, null);
        }
 
        private static String generateKey(Class<?> class1, Class<?> class2) {
            return class1.toString() + class2.toString();
        }
 
    /**
         ×通过常规反射形式
     * DTO对象转换为实体对象。如命名不规范或其他原因导致失败。
     * @param t 源转换的对象
     * @param e 目标转换的对象
     * 
     */
     public static <T,E> void transalte(T t,E e){
        Method[] tms=t.getClass().getDeclaredMethods();
        Method[] tes=e.getClass().getDeclaredMethods();
        for(Method m1:tms){
            if(m1.getName().startsWith("get")){
                String mNameSubfix=m1.getName().substring(3);
                String forName="set"+mNameSubfix;
                for(Method m2:tes){
                    if(m2.getName().equals(forName)){
                                            // 如果类型一致,或者m2的参数类型是m1的返回类型的父类或接口
                        boolean canContinue = m2.getParameterTypes()[0].isAssignableFrom(m1.getReturnType());
                        if (canContinue) {
                            try {
                                m2.invoke(e, m1.invoke(t));
                                break;
                            } catch (Exception e1) {
                                // TODO Auto-generated catch block
                            logger.debug("DTO 2 Entity转换失败");
                                e1.printStackTrace();
                            }
                        }
                    }
                }
            }
             
        }
        logger.debug("转换完成");
         
    }


}
在软件开发中,数据传输对象(DTO)和实体对象(Entity)通常具有不同的属性和用途,因此在应用程序中进行它们之间的换是很常见的。 一种常用的换方法是手动编写换代码,但这种方法可能会导致大量重复的代码和繁琐的工作。另一种方法是使用自动化换工具,例如MapStruct、ModelMapper等,这些工具可以生成换代码,从而减少了手动编写的工作量。 下面是一个使用MapStruct进行DTOEntity换的示例: 首先,在pom.xml文件中添加MapStruct依赖: ``` <dependency> <groupId>org.mapstruct</groupId> <artifactId>mapstruct</artifactId> <version>1.4.2.Final</version> </dependency> ``` 然后,定义DTOEntity: ``` public class UserDTO { private Long id; private String username; private String email; // getter和setter方法 } public class UserEntity { private Long id; private String username; private String email; // getter和setter方法 } ``` 接下来,创建换器接口并使用@Mapper注解标记它: ``` @Mapper public interface UserMapper { UserMapper INSTANCE = Mappers.getMapper(UserMapper.class); UserDTO toDto(UserEntity entity); UserEntity toEntity(UserDTO dto); } ``` 最后,在应用程序中使用换器进行DTOEntity之间的换: ``` UserDTO dto = UserMapper.INSTANCE.toDto(entity); UserEntity entity = UserMapper.INSTANCE.toEntity(dto); ``` 使用MapStruct可以简化DTOEntity之间的换,提高开发效率。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值