public class ProductDto
{
public int ID { get; set; }
public string Name { get; set; }
public string Category { get; set; }
public decimal Price { get; set; }
}
public class MappingProfile : Profile
{
public MappingProfile()
{
CreateMap()
.ForMember(dest => dest.ID, opt => opt.MapFrom(src => src.ProductID))
.ForMember(dest => dest.Name, opt => opt.MapFrom(src => src.ProductName))
.ForMember(dest => dest.Category, opt => opt.MapFrom(src => src.Category.CategoryName));
}
}
这将源模型"Product"映射到DTO类"ProductDto"。 4. 在Global.asax.cs文件中,添加以下代码以配置Automapper:
protected void Application_Start()
{
Mapper.Initialize(cfg => cfg.AddProfile());
//其他应用程序启动代码
}
现在你可以使用以下代码将数据从源模型转换为目标DTO模型:
var product = dbContext.Products.FirstOrDefault(p => p.ProductID == id);
var productDto = Mapper.Map(product);
这将使用Automapper配置将源"Product"模型映射到目标"ProductDto"模型。 5. (可选)你也可以使用Automapper创建一个逆映射,以便在需要时从DTO模型返回源模型。
CreateMap()
.ForMember(dest => dest.ProductID, opt => opt.MapFrom(src => src.ID))
.ForMember(dest => dest.ProductName, opt => opt.MapFrom(src => src.Name))
.ForMember(dest => dest.Category.CategoryName, opt => opt.MapFrom(src => src.Category));
现在你可以使用以下代码将数据从DTO模型转换回源模型:
var productDto = new ProductDto { ID = 1, Name = "Product A", Category = "Category X", Price = 10.00 };
var product = Mapper.Map(productDto);