AutoMapper:DTO与Entity之间的映射

AutoMapper: Mapping between DTO and Entity

我正在使用 ASP.NET 核心 WebAPI,我想为名为“Item”的对象执行 CRUD。 我正在使用 EF Core 来处理 SQL 数据库,并且我有两个代表我的对象的模型。

  1. ItemDto - 项目的数据传输对象
  2. ItemEntity - 数据库对象(表示 table 1:1 中的一行)

我的 HTTP GET one 和 HTTP GET many 方法的工作方式是

  1. 获取 ItemRepository 实例

  2. 获取一个或多个 ItemEntity

  3. 使用 AutoMapper 将其映射到 ItemDto 这是在我的构造函数中初始化的,例如

    m_itemDtoMapper = new Mapper(new MapperConfiguration(cfg => cfg.CreateMap<ItemEntity, ItemDto>()));
    

并且在我的 WebAPI 方法中,我使用以下行将其映射到 ItemDto(对于 GET 很多情况):

var itemDtos = m_itemDtoMapper.Map<IEnumerable<ItemEntity>, ICollection<ItemDto>>(items);

这很好用,而且 AutoMapper 非常强大。我现在的问题是:

  1. 这是管理数据库实体和数据传输对象之间关系的标准方式吗?
  2. 在CreateItem方法中,我需要做反向映射。我需要将 ItemDto 映射到 ItemEntity,而不是将 ItemEntity 映射到 ItemDto。我该怎么做?仅使用切换的实体创建我的映射器的副本是可行的,但它应该如何完成?即两个映射器。

在您的示例中,您似乎每次都初始化一个新的映射器实例。我建议您使用依赖注入并使用 AutoMapper 映射配置文件。

您可以通过三个简单的步骤完成,我认为它可以回答您的两个问题:

第 1 步: 只需创建一个名为 MappingProfile 或类似名称的新 class:

   public class MappingProfile: Profile
    {
        public MappingProfile()
        {
            CreateMap<User, AuthenticateDto>(); // One Way
            CreateMap<User, UserDto>().ReverseMap(); // Reverse
        }
    }

步骤 2: 在 Startup.cs

中注册 Automapper
   // Register AutoMapper
   services.AddAutoMapper(Assembly.GetExecutingAssembly());

第 3 步: 通过 DI 使用映射器

  public UserService(IMapper mapper) {
   _mapper = mapper;
  }
// call it as you already did
_mapper.Map<User, UserDto>(user);

希望对你有所帮助:)