繁体   English   中英

AutoMapper:DTO 和实体之间的映射

[英]AutoMapper: Mapping between DTO and Entity

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

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

我的 HTTP GET one 和 HTTP GET many methods 以这样的方式工作

  1. 获取 ItemRepository 实例

  2. 获取一个或多个ItemEntity

  3. Map 它使用 AutoMapper 到ItemDto这在我的构造函数中初始化,例如

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

在我的 WebAPI 方法中,我将 map 使用以下行传递给 ItemDto(对于 GET 很多情况):

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

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

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

在您的示例中,您似乎每次都初始化一个新的映射器实例。 我建议您使用 go 以及依赖注入并使用 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);

希望它可以帮助你:)

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM