From 17f0c20242c6ee3d35b9ee8f677d747ed012423c Mon Sep 17 00:00:00 2001 From: 疯狂的狮子li <15040126243@163.com> Date: 星期五, 02 九月 2022 16:30:20 +0800 Subject: [PATCH] remove 移除maven docker插件 过于老旧功能缺陷大 使用idea自带的docker插件替代 --- ruoyi-common/src/main/java/com/ruoyi/common/utils/BeanCopyUtils.java | 78 +++++++++++++++++++++++++++++++++++--- 1 files changed, 71 insertions(+), 7 deletions(-) diff --git a/ruoyi-common/src/main/java/com/ruoyi/common/utils/BeanCopyUtils.java b/ruoyi-common/src/main/java/com/ruoyi/common/utils/BeanCopyUtils.java index 0bd4a55..88161da 100644 --- a/ruoyi-common/src/main/java/com/ruoyi/common/utils/BeanCopyUtils.java +++ b/ruoyi-common/src/main/java/com/ruoyi/common/utils/BeanCopyUtils.java @@ -1,18 +1,26 @@ package com.ruoyi.common.utils; import cn.hutool.core.collection.CollUtil; +import cn.hutool.core.lang.SimpleCache; import cn.hutool.core.map.MapUtil; import cn.hutool.core.util.ObjectUtil; import cn.hutool.core.util.ReflectUtil; -import cn.hutool.extra.cglib.CglibUtil; +import cn.hutool.core.util.StrUtil; import lombok.AccessLevel; import lombok.NoArgsConstructor; +import org.springframework.cglib.beans.BeanCopier; +import org.springframework.cglib.beans.BeanMap; +import org.springframework.cglib.core.Converter; import java.util.List; import java.util.Map; /** * bean娣辨嫹璐濆伐鍏�(鍩轰簬 cglib 鎬ц兘浼樺紓) + * <p> + * 閲嶇偣 cglib 涓嶆敮鎸� 鎷疯礉鍒伴摼寮忓璞� + * 渚嬪: 婧愬璞� 鎷疯礉鍒� 鐩爣(閾惧紡瀵硅薄) + * 璇峰尯鍒嗗ソ`娴呮嫹璐漙鍜宍娣辨嫹璐漙鍐嶅仛浣跨敤 * * @author Lion Li */ @@ -33,7 +41,8 @@ if (ObjectUtil.isNull(desc)) { return null; } - return CglibUtil.copy(source, desc); + final V target = ReflectUtil.newInstanceIfPossible(desc); + return copy(source, target); } /** @@ -50,7 +59,8 @@ if (ObjectUtil.isNull(desc)) { return null; } - CglibUtil.copy(source, desc); + BeanCopier beanCopier = BeanCopierCache.INSTANCE.get(source.getClass(), desc.getClass(), null); + beanCopier.copy(source, desc, null); return desc; } @@ -68,7 +78,11 @@ if (CollUtil.isEmpty(sourceList)) { return CollUtil.newArrayList(); } - return CglibUtil.copyList(sourceList, () -> ReflectUtil.newInstanceIfPossible(desc)); + return StreamUtils.toList(sourceList, source -> { + V target = ReflectUtil.newInstanceIfPossible(desc); + copy(source, target); + return target; + }); } /** @@ -77,11 +91,12 @@ * @param bean 鏁版嵁鏉ユ簮瀹炰綋 * @return map瀵硅薄 */ + @SuppressWarnings("unchecked") public static <T> Map<String, Object> copyToMap(T bean) { if (ObjectUtil.isNull(bean)) { return null; } - return CglibUtil.toMap(bean); + return BeanMap.create(bean); } /** @@ -98,7 +113,8 @@ if (ObjectUtil.isNull(beanClass)) { return null; } - return CglibUtil.toBean(map, beanClass); + T bean = ReflectUtil.newInstanceIfPossible(beanClass); + return mapToBean(map, bean); } /** @@ -115,6 +131,54 @@ if (ObjectUtil.isNull(bean)) { return null; } - return CglibUtil.fillBean(map, bean); + BeanMap.create(bean).putAll(map); + return bean; } + + /** + * BeanCopier灞炴�х紦瀛�<br> + * 缂撳瓨鐢ㄤ簬闃叉澶氭鍙嶅皠閫犳垚鐨勬�ц兘闂 + * + * @author Looly + * @since 5.4.1 + */ + public enum BeanCopierCache { + /** + * BeanCopier灞炴�х紦瀛樺崟渚� + */ + INSTANCE; + + private final SimpleCache<String, BeanCopier> cache = new SimpleCache<>(); + + /** + * 鑾峰緱绫讳笌杞崲鍣ㄧ敓鎴愮殑key鍦▄@link BeanCopier}鐨凪ap涓搴旂殑鍏冪礌 + * + * @param srcClass 婧怋ean鐨勭被 + * @param targetClass 鐩爣Bean鐨勭被 + * @param converter 杞崲鍣� + * @return Map涓搴旂殑BeanCopier + */ + public BeanCopier get(Class<?> srcClass, Class<?> targetClass, Converter converter) { + final String key = genKey(srcClass, targetClass, converter); + return cache.get(key, () -> BeanCopier.create(srcClass, targetClass, converter != null)); + } + + /** + * 鑾峰緱绫讳笌杞崲鍣ㄧ敓鎴愮殑key + * + * @param srcClass 婧怋ean鐨勭被 + * @param targetClass 鐩爣Bean鐨勭被 + * @param converter 杞崲鍣� + * @return 灞炴�у悕鍜孧ap鏄犲皠鐨刱ey + */ + private String genKey(Class<?> srcClass, Class<?> targetClass, Converter converter) { + final StringBuilder key = StrUtil.builder() + .append(srcClass.getName()).append('#').append(targetClass.getName()); + if(null != converter){ + key.append('#').append(converter.getClass().getName()); + } + return key.toString(); + } + } + } -- Gitblit v1.9.3