博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
AutoMapper在C#中的有趣应用
阅读量:4482 次
发布时间:2019-06-08

本文共 3127 字,大约阅读时间需要 10 分钟。

原文:

最近发现了一个比较有趣的东西 AutoMapper,主要将Model转换为DTO,DTO更注重数据,对领域对象进行合理封装,从而不会将领域对象的行为过分暴露给表现层。

先来看一点实例,两个类之间的映射。

首先定义两个类Source与DTOSource:

1  public class Source 2     { 3         public int Id { get; set; } 4         public string Content { get; set; } 5     } 6  7     public class DTOSource 8     { 9         public int Id { get; set; }10         public string Content { get; set; }11     }

 Source与DTOSource字段完全相同,来看看它俩如何通过AutoMapper转换,代码很简单。

1 Mapper.Initialize(x=>{2      x.CreateMap
();3 });4 5 Source s = new Source{Id=1,Content="123"};6 7 DTOSource dto = Mapper.Map
(s);

第一步建立Source到DTOSource之间的映射,初始化一个Source实例后,来看下执行结果:

执行完成后,可以看到dto中的数据与之前初始化的s的数据是一样的,就像是直接将s拷贝了一份给dto,在两个类字段名定全相同的情况下如此,那么如果DTOSource中的字段名与Source中的不相同如何,其实也很简单,只需

要改成一点点的代码既可:

我们将DTOSource中的Content的字段名改成Desc,此时只需要建立映射关系时,指定字段就可以了:

1 Mapper.Initialize(x => {2    x.CreateMap
().ForMember(c=>c.Desc,q=> {3 q.MapFrom(z => z.Content);4 });5 });

来看看运行结果如何;

可以看到与之前的运行结果是相同的。

那么如何映射两个List,其实也很简单,和上述代码几乎可以说是无差别,只是在最后一步时,要做一点点的修改就可以了。如下面代码:

1  Mapper.Initialize(x => { 2                 x.CreateMap
().ForMember(c => c.Desc, q => 3 { 4 q.MapFrom(z => z.Content); 5 }); 6 }); 7 8 s.Add(new Source { Id = 1, Content = "123" }); 9 10 var dto = Mapper.Map
>(s);

 

可以看到除了最后一句代码,其它几乎是完全相同的,只是在最后一句代码中,目标类型改成了List<DTOSource>仅此而已。看下运行结果如何:

结果符合预期。

在实际的项目中,这样的写法肯定是不符合要求的,一般会做一个封装,新建一个SourceProfile继承自Profile:

1  public SourceProfile()2         {3             base.CreateMap
().ForMember(c => c.Desc, q => {4 q.MapFrom(z => z.Content);5 });6 }

所有映射关系都可以写在这一个类里,只需要在程序初始化的时候调用一次就可以了:

 1 Mapper.Initialize(x => x.AddProfile<SourceProfile>();  }); 

博主使用的AutoMapper版本6.1.1.0,因为AutoMapper在6.0版本时移除了Profile中的Configure,所以与6.0版本以下写法有点不同,6.0以下版本写法为:

1 public class SourceProfile : Profile2     {3         protected override void Configure()4         {5             CreateMap
().ForMember(c => c.Desc, q => {6 q.MapFrom(z => z.Content);7 });8 }9 }

继承Profile重写其Configure即可,调用方式与上述没有太大差别。 Mapper.Initialize中可添加一个或多个Profile。

在MVC项目的应用中,可以将Mapper.Initialize封装到一个类里;

public static class AutoMapperForMvc    {        public  static void Register() { Mapper.Initialize(x => { x.AddProfile
(); }); } }

 进而在MVC的Global中进一次性注册:

1 public class MvcApplication : System.Web.HttpApplication 2     { 3         protected void Application_Start() 4         { 5             AreaRegistration.RegisterAllAreas(); 6             FilterConfig.RegisterGlobalFilters(GlobalFilters.Filters); 7             RouteConfig.RegisterRoutes(RouteTable.Routes); 8             BundleConfig.RegisterBundles(BundleTable.Bundles); 9             //注册10             AutoMapperForMvc.Register();11         }12     }

 更多有趣的东西可以查看

posted on
2019-01-08 00:24 阅读(
...) 评论(
...)

转载于:https://www.cnblogs.com/lonelyxmas/p/10236709.html

你可能感兴趣的文章
Mongo索引
查看>>
php 实现设计模式之 建造者模式
查看>>
An Easy C Program Problem
查看>>
Replace Nested Conditional with Guard Clauses(用卫语句代替嵌套循环)
查看>>
jsp中${}是EL表达式的常规表示方式
查看>>
GoldenGate常见问题及处理
查看>>
Android JNI学习(五)——Demo演示
查看>>
SSRS 呈现Barcode Free
查看>>
java快速排序引起的StackOverflowError异常
查看>>
泛函编程(35)-泛函Stream IO:IO处理过程-IO Process
查看>>
-XX:-PrintClassHistogram 按下Ctrl+Break后,打印类的信息
查看>>
mac 安装php redis扩展
查看>>
css3中Animation
查看>>
JS 判断是否是手机端并跳转操作
查看>>
最短路径问题(dijkstra-模板)
查看>>
c# 导出表格 api
查看>>
使用Android NDK以及JNI编写应用
查看>>
学习笔记之-php数组数据结构
查看>>
初学者--bootstrap(六)组件中的下拉菜单----在路上(10)
查看>>
QMetaObject::connectSlotsByName 总结
查看>>