Mapstruct Mapper的使用--使用命名的工具类及其方法

通过mapper 把id转换成名称
DmMaintenanceBenefitMapper.java

@Mapper(componentModel = "spring", uses = {BaseInfoUtils.class})
public interface DmMaintenanceBenefitMapper {
@Mappings(
    @Mapping(source = "cityId",target = "cityName",qualifiedByName = {"BaseInfoUtils","getCityNameById"})
)//写上使用的类和方法的名称
    DmMaintenanceBenefitDTO objToDTO(DmMaintenanceBenefit record);

    List<DmMaintenanceBenefitDTO> objsToDTOs(List<DmMaintenanceBenefit> records);

}

BaseInfoUtils.java

@Named("BaseInfoUtils")//给类命名
@Component
public class BaseInfoUtils {   

     @Named("getCityNameById")//给方法名称
    public String getCityNameById(String cityId){
//通过getBean使用其他的类
        CommonService commonService = SpringUtils.getBean(CommonService.class);
        return cityId == null? "" : commonService.getCityNameByCityId(cityId);

    }



}

 

 

SpringUtils.java

//
// Source code recreated from a .class file by IntelliJ IDEA
// (powered by Fernflower decompiler)
//

package com.troy.keeper.common.core.util;

import java.util.Map;
import org.springframework.beans.BeansException;
import org.springframework.beans.factory.NoSuchBeanDefinitionException;
import org.springframework.beans.factory.config.BeanFactoryPostProcessor;
import org.springframework.beans.factory.config.ConfigurableListableBeanFactory;
import org.springframework.context.ApplicationContext;
import org.springframework.context.ApplicationContextAware;
import org.springframework.stereotype.Component;

@Component
public class SpringUtils implements BeanFactoryPostProcessor, ApplicationContextAware {
/*

BeanFactoryPostProcessor

bean工厂的bean属性处理容器,说通俗一些就是可以管理我们的bean工厂内所有的beandefinition(未实例化)数据,可以随心所欲的修改属性。

*/

    private static ConfigurableListableBeanFactory beanFactory;
    private static ApplicationContext ctx;

    public SpringUtils() {
    }

    public void setApplicationContext(ApplicationContext ctx) throws BeansException {
        ctx = ctx;
    }

    public void postProcessBeanFactory(ConfigurableListableBeanFactory beanFactory) throws BeansException {
        beanFactory = beanFactory;
    }

    public static <T> T getBean(String name) throws BeansException {
        return beanFactory.getBean(name);
    }

    public static <T> T getBean(Class<T> clz) throws BeansException {
        T result = beanFactory.getBean(clz);
        return result;
    }

    public static boolean containsBean(String name) {
        return beanFactory.containsBean(name);
    }

    public static boolean isSingleton(String name) throws NoSuchBeanDefinitionException {
        return beanFactory.isSingleton(name);
    }

    public static Class<?> getType(String name) throws NoSuchBeanDefinitionException {
        return beanFactory.getType(name);
    }

    public static String[] getAliases(String name) throws NoSuchBeanDefinitionException {
        return beanFactory.getAliases(name);
    }

    public static <T> Map<String, T> getBeansOfType(Class<T> type) {
        return ctx.getBeansOfType(type);
    }

    public static String[] getBeanNamesForType(Class<?> type) {
        return ctx.getBeanNamesForType(type);
    }
}

 

 

MapStruct是一种Java bean映射工具,可以简化Java bean之间的映射过程。MapperConfig和Named注解是MapStruct中的两个重要注解。 MapperConfig注解用于标注一个接口,它可以包含多个映射方法。这些方法可以被其他映射器接口引用,从而避免在每个接口中重复定义映射方法。当一个接口被标注为MapperConfig时,MapStruct会自动生成一个实现类,这个实现类包含了所有在接口中定义的映射方法。 例如,我们有一个User和UserDto之间的映射接口: ```java @Mapper public interface UserMapper { UserDto toDto(User user); User toEntity(UserDto dto); } ``` 如果我们需要在另一个映射接口中使用这些方法,可以使用MapperConfig注解: ```java @MapperConfig(componentModel = "spring") public interface BaseMapper { UserMapper userMapper(); @Named("toEntityList") default List<User> toEntityList(List<UserDto> dtos) { return dtos.stream().map(this::toEntity).collect(Collectors.toList()); } } ``` 在这个例子中,我们定义了一个BaseMapper接口,并使用MapperConfig注解将UserMapper接口引入到BaseMapper中。我们还定义了一个名为toEntityList的方法,并使用Named注解标注了这个方法。这个方法将UserDto的列表转换为User的列表,并使用toEntity方法进行映射。 使用这些方法的示例代码如下: ```java @Mapper(uses = BaseMapper.class) public interface OrderMapper { OrderDto toDto(Order order); Order toEntity(OrderDto dto); @Named("toEntityList") default List<Order> toEntityList(List<OrderDto> dtos) { return dtos.stream().map(this::toEntity).collect(Collectors.toList()); } } ``` 在OrderMapper中,我们使用了BaseMapper中的UserMapper和toEntityList方法。我们还定义了一个名为toEntityList的方法,并使用Named注解标注了这个方法,这个方法将OrderDto的列表转换为Order的列表,并使用toEntity方法进行映射。 通过使用MapperConfig注解和Named注解,我们可以避免在每个映射接口中重复定义映射方法,提高代码的复用性和可维护性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值