AutoMapper学习

AutoMapper学习http://automapper.org/这是一款DTO的映射工具,AutoMapper是基于对象到对象约定的映射工具,它可以把复杂的对象模型转为DTO,或者其他的–那些让设计更合理更适于序列化、通信、传递消息的简单对象或者干脆就只是在领域层与应用层之间搭建一个简单的ACL防护层(就像DTO一样,用于代码的显示转换)来增加各自层的相互独立性。简单来说就是:就是根据A的模型和B的模型中的定义,自动将A模型映射为一个全新的B模型。前言VO、DTO、DO、PO、DAOVO(ViewObject.

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全家桶1年46,售后保障稳定

http://automapper.org/
这是一款DTO的映射工具,AutoMapper是基于对象到对象约定的映射工具,它可以把复杂的对象模型转为DTO,或者其他的–那些让设计更合理更适于序列化、通信、传递消息的简单对象或者干脆就只是在领域层与应用层之间搭建一个简单的ACL防护层(就像DTO一样,用于代码的显示转换)来增加各自层的相互独立性。

简单来说就是:就是根据A的模型和B的模型中的定义,自动将A模型映射为一个全新的B模型。

前言

VO、DTO、DO、PO、DAO

  • VO(View Object):视图对象,用于展示层,它的作用是把某个指定页面(或组件)的所有数据封装起来。
  • DTO(Data Transfer Object):数据传输对象,泛指用于展示层与服务层之间的数据传输对象。
  • DO(Domain Object):领域对象,就是从现实世界中抽象出来的有形或无形的业务实体。
  • PO(Persistent Object):持久化对象,它跟持久层(通常是关系型数据库)的数据结构形成一一对应的映射关系,如果持久层是关系型数据库,那么,数据表中的每个字段(或若干个)就对应PO的一个(或若干个)属性。
  • DAO(Data Access Object):数据访问对象,主要用来封装对数据库的操作。

为什么要有DTO

通常我们通过DAO获取POPO是和数据库映射的,但是可能包含了很多对于传输来说并不需要的属性。

比如一张表有100个字段,那么对应的PO可能就是100个属性,但是对于表示层而言并不需要那么多属性展示给用户,同样的也不应该把底层表结构暴露给表示层,那么中间就有一个DTO对象的转换,表示层需要多少属性则DTO的设置就定义多少属性。

应用场景

人工转换

我们经常需要有这样的转换,将PO模型转换为实际传递需要的DTO模型,如果人工方式实现就会有一堆如下繁琐、效率低下的代码:

    class Program
    { 
   
        static void Main(string[] args)
        { 
   
            // PO->DTO 的人工转换
            StudentPO po = new StudentPO() { 
    ID = 1, FirstName = "Money", LastName = "Wang", Password = "admin", UserID = "imwyw" };
            StudentDTO dto = new StudentDTO()
            { 
   
                FirstName = po.FirstName,
                LastName = po.LastName,
                UserID = po.UserID
            };
        }
    }
    /// <summary>
    /// Persistence Object
    /// 模拟PO,库表映射对象
    /// </summary>
    public class StudentPO
    { 
   
        public int ID { 
    get; set; }
        public string FirstName { 
    get; set; }
        public string LastName { 
    get; set; }
        public int Sex { 
    get; set; }
        public DateTime Birth { 
    get; set; }
        public string UserID { 
    get; set; }
        public string Password { 
    get; set; }
        public string Address { 
    get; set; }
    }
    /// <summary>
    /// DTO Data Transport Object 数据传输对象
    /// 轻量级,并不是PO的所有属性
    /// </summary>
    public class StudentDTO
    { 
   
        public string FirstName { 
    get; set; }
        public string LastName { 
    get; set; }
        public string UserID { 
    get; set; }
    }

Jetbrains全家桶1年46,售后保障稳定

AutoMapper安装

同样,我们通过NuGet程序包管理器进行安装引用:
在这里插入图片描述

默认映射

AutoMapper uses a convention-based matching algorithm to match up source to destination values.
在使用AutoMapper进行映射对象前,还需要initialize AutoMapper,参考官网提欧的方法:

http://automapper.readthedocs.io/en/latest/Static-and-Instance-API.html
我们以官网中提供的static api作为示例:

class Program
{ 
   
    static void Main(string[] args)
    { 
   
        MapperInit();
        StudentPO po = new StudentPO() { 
    ID = 1, FirstName = "Money", LastName = "Wang", Password = "admin", UserID = "imwyw" };
        //使用Mapper 将po转换为dto
        StudentDTO dto1 = AutoMapper.Mapper.Map<StudentPO, StudentDTO>(po);
        //使用Mapper 将dto转换为po,没有的属性赋默认值
        StudentPO po1 = AutoMapper.Mapper.Map<StudentDTO, StudentPO>(new StudentDTO() { 
    FirstName = "First", LastName = "Last", UserID = "samsung" });
    }
    /// <summary>
    /// Mapper初始化,在程序启动的时候进行一次初始化
    /// You now must use either Mapper.Initialize or new MapperConfiguration() to initialize AutoMapper. 
    /// If you prefer to keep the static usage, use Mapper.Initialize.
    /// </summary>
    static void MapperInit()
    { 
   
        //static api 我们使用静态方法进行初始化
        AutoMapper.Mapper.Initialize(cfg =>
        { 
   
            cfg.CreateMap<StudentPO, StudentDTO>();
            cfg.CreateMap<StudentDTO, StudentPO>();
        });
        //在程序启动时对所有的配置进行严格的验证
        AutoMapper.Mapper.AssertConfigurationIsValid();
    }
}
/// <summary>
/// Persistence Object
/// 模拟PO,库表映射对象
/// </summary>
public class StudentPO
{ 
   
    public int ID { 
    get; set; }
    public string FirstName { 
    get; set; }
    public string LastName { 
    get; set; }
    public int Sex { 
    get; set; }
    public DateTime Birth { 
    get; set; }
    public string UserID { 
    get; set; }
    public string Password { 
    get; set; }
    public string Address { 
    get; set; }
}
/// <summary>
/// DTO Data Transport Object 数据传输对象
/// 轻量级,并不是PO的所有属性
/// </summary>
public class StudentDTO
{ 
   
    public string FirstName { 
    get; set; }
    public string LastName { 
    get; set; }
    public string UserID { 
    get; set; }
}

Reverse Mapping

反向映射,在上述的示例中,进行了PO->DTODTO->PO转换的映射,我们也可以通过反向映射来代替:

//static api 我们使用静态方法进行初始化
AutoMapper.Mapper.Initialize(cfg =>
{ 
   
    cfg.CreateMap<StudentPO, StudentDTO>().ReverseMap();
    //cfg.CreateMap<StudentDTO, StudentPO>(); 不再需要
});

Customizing reverse mapping

默认的映射有时候可能并不符合我们的需求,对于以下属性名称并不相同的映射需求,我们可以ForMember()自定义映射关系:

class Program
{ 
   
    static void Main(string[] args)
    { 
   
        AutoMapper.Mapper.Initialize(cfg =>
        { 
   
            cfg.CreateMap<StudentPO, StudentDTO>()
            .ForMember(des => des.EnName, op => op.MapFrom(src => src.ZhName))
            //.ForMember("EnName", op => op.MapFrom(src => src.ZhName)) ForMember重载,作用同上
            .ReverseMap();
        });
        StudentDTO dto = AutoMapper.Mapper.Map<StudentPO, StudentDTO>(new StudentPO() { 
    ZhName = "杰克" });
        StudentPO po = AutoMapper.Mapper.Map<StudentDTO, StudentPO>(new StudentDTO() { 
    EnName = "jack" });
    }
}
public class StudentPO
{ 
   
    public string ZhName { 
    get; set; }
}
public class StudentDTO
{ 
   
    public string EnName { 
    get; set; }
}

在映射对象时,我们还可以进行自定义的投影操作,可以在lambda表达式中定义我们需要的任意投影需要:

class Program
{ 
   
    static void Main(string[] args)
    { 
   
        AutoMapper.Mapper.Initialize(cfg =>
        { 
   
            cfg.CreateMap<BirthInfo, BirthDto>()
            .ForMember(des => des.BirthYear, op => op.MapFrom(src => src.Birth.Year))
            .ForMember(des => des.BirthMonth, op => op.MapFrom(src => src.Birth.Month))
            .ForMember(des => des.BirthDay, op => op.MapFrom(src => src.Birth.Day));
        });
        BirthDto dto = AutoMapper.Mapper.Map<BirthInfo, BirthDto>(new BirthInfo() { 
    Name = "Jack", Birth = Convert.ToDateTime("1900-9-19") });
    }
}
public class BirthInfo
{ 
   
    public string Name { 
    get; set; }
    public DateTime Birth { 
    get; set; }
}
public class BirthDto
{ 
   
    public string Name { 
    get; set; }
    public int BirthYear { 
    get; set; }
    public int BirthMonth { 
    get; set; }
    public int BirthDay { 
    get; set; }
}
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/200837.html原文链接:https://javaforall.net

(0)
上一篇 2025年8月20日 下午4:15
下一篇 2025年8月20日 下午4:43


相关推荐

  • PKCS11接口解析「建议收藏」

    PKCS11接口解析「建议收藏」pkcs密码中间件位于上层应用和底层安全设备之间,应用基于PKCS#11标准接口开发各类应用程序。主要包括2个库主API库:提供给应用的PKCS11接口。 tokenDLL库:由主API库调用,完成从上向下到指定设备的套接。 安全密码设备:安全服务资源和实施的载体,完成具体安全功能支撑。表pkcs11函数接口 种类 函数 …

    2022年5月24日
    47
  • CPU性能测试工具-Unixbench

    CPU性能测试工具-Unixbench简介 UnixBench 是一个类 unix 系 Unix BSD Linux 统下的性能测试工具 一个开源工具 被广泛用与测试 linux 系统主机的性能 Unixbench 的主要测试项目有 系统调用 读写 进程 图形化测试 2D 3D 管道 运算 C 库等系统基准性能提供测试数据 unixbench 一个基于系统的基准测试工具 不单纯是 CPU 内存或者磁盘测试工具 测试结果不仅仅取决于硬件 也取决于系

    2026年3月16日
    4
  • NoSQL数据库的五种分类

    NoSQL数据库的五种分类NoSQL 数据库分为五种 键值数据库 文档数据库 列式数据库 图数据库 全文搜索引擎数据库

    2025年9月12日
    5
  • 计算机用户名和密码怎么查_计算机名在哪看

    计算机用户名和密码怎么查_计算机名在哪看有时外人随意使用翻看办公电脑的问题,特别是当电脑里面存储了一些保密文件的时候,是不能随便让人看的,所以小设置电脑开机密码是有发要的。下面是学习小编给大家整理的有关介绍windowsxp电脑设置、修改开机密码的方法,希望对大家有帮助!windowsxp电脑设置、修改开机密码的方法首先,点击【开始】菜单,然后选择”控制面板“选项。在控制面板的对话框中找到”用户账户“选项,并点击进入。在用户账户对话…

    2022年10月14日
    4
  • WebStorm强大的调试JavaScript功能

    WebStorm强大的调试JavaScript功能一、JavaScript的调试目前火狐和Chrome都具备调试JavaScript的功能,而且还是相当的强大。如果纯粹是用浏览器来进行js调试的话,我比较喜欢用火狐。火狐可以安装各种插件,真的是非常适合开发者。不过今天的主角并不是火狐,也不是Chrome,而是号称最智能的JavaScriptIDE:WebStorm。WebStorm是jetbrains公司旗下一款JavaScript开发

    2025年8月14日
    3
  • sinx的泰勒展开式

    sinx的泰勒展开式sinx 的泰勒展开式求解过程思路 sinx 可以如何 展开 写成式子就是 最后以省略号结束 代表 无穷 需要求的就是 a0 a1 a2 的值 准确地说就是通项公式 然后 我们就可以开始 微分 了 就是等式两边同时 不停地微分下去 左边的三角函数的微分 其实是四个一循环的 sinx cosx sinx cosx 再回到 sinx

    2025年6月25日
    2

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号