AutoMapper 是 C# 中最常用的对象映射库,用来简化两个不同结构的类(比如 DTO 和实体)之间的属性赋值。它不靠反射硬编码,而是通过配置一次、复用多次,让代码更干净、可维护性更高。
安装和基础配置
在 .NET 项目中,用 NuGet 安装 AutoMapper:
Package Manager:`Install-Package AutoMapper` CLI:`dotnet add package AutoMapper`从 AutoMapper 12.0 开始,推荐使用 MapperConfiguration + IMapper 方式(替代旧版静态 Mapper)。在 Startup 或 Program.cs 中注册:
var mappingConfig = new MapperConfiguration(mc =>
{
mc.CreateMap<User, UserDto>();
mc.CreateMap<UserDto, User>();
});
var mapper = mappingConfig.CreateMapper();如果是 ASP.NET Core 项目,更推荐用依赖注入方式注册:
services.AddAutoMapper(typeof(Program)); // 扫描 Program 类所在程序集中的 Profile
用 Profile 组织映射规则
把映射逻辑集中管理,避免配置散落在各处。新建一个继承 Profile 的类:
public class UserMappingProfile : Profile
{
public UserMappingProfile()
{
CreateMap<User, UserDto>()
.ForMember(dest => dest.FullName, opt => opt.MapFrom(src => $"{src.FirstName} {src.LastName}"))
.ForMember(dest => dest.Age, opt => opt.MapFrom(src => DateTime.Now.Year - src.BirthDate.Year));
<pre class="brush:php;toolbar:false;"> CreateMap<UserDto, User>()
.ForMember(dest => dest.BirthDate, opt => opt.Ignore()); // 忽略不映射的字段
}}
Profile 会自动被
AddAutoMapper发现并加载,无需手动添加。
执行映射操作
注入 IMapper 后直接调用:
mapper.Map<userdto>(user)</userdto>—— 对象转 DTO
mapper.Map(userDto, user)—— 更新已有对象(目标对象不为空)
mapper.Map<list>>(users)</list>—— 集合映射(自动识别泛型)
注意:AutoMapper 默认按属性名匹配(忽略大小写),同名且类型兼容的字段自动复制;类型不一致或名称不同需用
ForMember显式配置。
常见问题与建议
映射失败时不会抛异常,但可能静默跳过字段。建议开发阶段开启验证:
var config = new MapperConfiguration(c => c.AddProfile<UserMappingProfile>()); config.AssertConfigurationIsValid(); // 启动时检查映射是否合法避免在映射中调用数据库或耗时操作,保持纯数据转换 敏感字段(如密码)记得用
Ignore()或
MapFrom(x => null)复杂嵌套对象支持深度映射,但要确保所有中间类型都有对应 CreateMap
基本上就这些。用熟了 Profile + IMapper,日常 DTO 转换几行代码搞定,不复杂但容易忽略验证和命名约定。
