下面正式开始今天的讲解。
首先,让我们稍微回忆一下AutoMapper的知识点。
问:什么是AutoMapper?
答:AutoMapper翻译过来就是“自动映射工具”。它的作用就是将一个源类型映射成一个目标类型,比如Person——>PersonDto,User——>UserDto。
问:什么情况下使用AutoMapper?
答:一般在项目的开发中,经常需要将Entity实体映射成ModelDto或者ViewModel,这个时候,使用AutoMapper仅需要简单的配置,就可以实现这些需求,非常方便。
接下来,讲一下项目中的具体配置。
在我的ABP项目中,首先核心层有一个实体类TerminalDevices,类定义如下:

View Code
可以看到,仅一个实体类,就要将近300行的代码,但是在服务层或者展现层使用的时候,有些属性是不需要的,所以这时我们就要定义我们的Dto类了。
随后,我在ABP项目中的服务层定义了一个对应的TerminalDeviceDto类,定义如下:

当然,这里的Dto类定义的属性跟你的具体业务相关,定义的属性还可能更少。
上面讲的是源类型和目标类型的定义,下面开始讲它们之间的映射配置。
首先,我在应用服务层新建一个文件夹取名“AutoMapper”,里面放跟AutoMapper配置相关的东西。
如图,新建一个类TerminalDeviceProfile(CityProfile类是我的另一个实体类对应的AutoMapper配置文件),定义如下:
再创建一个AutoMapperWebConfig静态类,定义如下:
接下来,在应用服务层的模块类中调用该静态类的静态方法,加载所有的AutoMapper配置信息。
这里需要注意的是,AutoMapper的配置一般放在项目启动的时候进行加载且只加载一次就够了,而在ABP框架搭建的项目中,除了展现层(Web和WebAPI层),其他层都会有一个Module类(类名以Module结尾)。这些类都重写了父类AbpModule的Initialize方法,旨在模块初始化的时候调用,这样,映射的配置也在模块初始化的时候完成了。如果在一般的ASP.Net项目中,应该在全局配置文件Global.asax中的Application_Start方法中调用AutoMapper的配置方法,其他项目类似。
以后,想要添加配置信息时,只需要定义相应的XXProfile类,然后在AutoMapperWebConfig类中添加配置文件类就可以了。
本文转自tkbSimplest博客园博客,原文链接:http://www.cnblogs.com/farb/p/4973910.html,如需转载请自行联系原作者