Auto Mapper02《demo》
2018-06-17 21:20:59来源:未知 阅读 ()
学习这些基本上网上都有一些教程或者别人做的demo,我是按照这个方式去学习的。先做个demo,学会如何去使用它,接着去慢慢的了解它是如何的运行的,理解里面的一些基本的基础知识。我们不可以再像学校里面的那样,先去学习基本的结构,那样我们会很烦脑的,我们应该先学会使用它,接着再去慢慢的了解。
“高内聚低耦合,尽量依赖抽象而不依赖于具体”,这个在面向对象的开发中是很常见的,autoMapper就可以很好的解释这个。automapper具体的功能就是将数据库中的实体表转换为我们页面上使用的model,虽然我们可以直接使用实体的Model,但是我们为了以后着想,界面上使用我们自己定义的Modell,只需要我们利用automapper进行转换就可以了。因为我们的实体Model是最容易发生变化的。
下面是我安装网上的教程做的demo。
书类
//书店 public class BookStore { public string Name { get; set; } public List<Book> Books { get; set; } public Address Address { get; set; } } //书店的地址 public class Address { public string Country { get; set; } public string City { get; set; } public string Street { get; set; } public string PostCode { get; set; } } // 书类 public class Book { public string Title { get; set; } public string Description { get; set; } public string Lauguage { get; set; } public decimal Price { get; set; } public DateTime? PublishDate { get; set; } public Publisher Publisher { get; set; } public int? Paperback { get; set; } public List<Author> Authors { get;set; } } //出版信息 public class Publisher { public string Name { get; set; } } //每本书都有2个作者 public class Author { public string Name { get; set; } public string Description { get; set; } public ContactInfo ContactInfo { get; set; } } //联系法式 public class ContactInfo { public string Email { get; set; } public string Blog { get; set; } public string Twitter { get; set; } }
书Dto
//书店 public class BookStoreDto { public string Name { get; set; } public List<BookDto> Books { get; set; } public AddressDto Address { get; set; } } //书店地址 public class AddressDto { public string Country { get; set; } public string City { get; set; } public string Street { get; set; } public string PostCode { get; set; } } //这个是对应的Book类 public class BookDto { public string Title { get; set; } public string Description { get; set; } public string Language { get; set; } public decimal Price { get; set; } public DateTime? PublishDate { get; set; } public string Publisher { get; set; } public int? Paperback { get; set; } //01作者信息 public string FirstAuthorName { get; set; } public string FirstAuthorDescription { get; set; } public string FirstAuthorEmail { get; set; } public string FirstAuthorBlog { get; set; } public string FirstAuthorTwitter { get; set; } //02作者信息 public string SecondAuthorName { get; set; } public string SecondAuthorDescription { get; set; } public string SecondAuthorEmail { get; set; } public string SecondAuthorBlog { get; set; } public string SecondAuthorTwitter { get; set; } }
我们可以发现dto里面将book的整个层级结构 ,全面拉平了,就是说放到了一个类里面,其实我们强大的AutoMapper是可以自动的进行映射的,还有我们的名字不一样的,但是只要是后面的是一样的是可以映射的。
//Mapper.CreateMap<AddressDto, Address>(); AddressDto dto=new AddressDto() { Country = "China", City = "XiAn", Street = "YUlin", PostCode = "001" }; //配置二者的转换 Mapper.CreateMap<AddressDto, Address>(); //这个映射的时候是从左向右的 Address address = Mapper.Map<AddressDto,Address>(dto); Console.WriteLine(address.Country); Console.WriteLine(address.PostCode); Console.ReadKey();
规则:
1:若是一个里面有空属性,那么利用AutoMapper映射过去相应的属性就会为空。
2:可以进行手工的传递。直接就是DTO中的一个属性可以直接映射到Modle中的一个类,但是需要我们自己进行设置。AutoMapper利用ForMember来指定每一个字段的映射规则的。
Mapper.CreateMap<Blog, Model>().ForMember(x => x.BlogCon, mo => mo.MapFrom(x => x.BlogContext));
bookDto的转换
//集合初始化器 BookStoreDto dto=new BookStoreDto() { Name = "ahui", Address = new AddressDto { City = "YUlin" }, Books = new List<BookDto> { new BookDto { Title = "你好世界" }, new BookDto { Title = "世界你好" } } }; //配置,这里要将转换的内容全部进行配置 Mapper.CreateMap<BookStoreDto, BookStore>(); Mapper.CreateMap<AddressDto, Address>(); Mapper.CreateMap<BookDto, Book>(); //IMappingExpression<BookDto, Book> expression = Mapper.CreateMap<BookDto, Book>(); //转换 BookStore bookStore = Mapper.Map<BookStoreDto,BookStore>(dto); //利用bookStore输出 Console.WriteLine(bookStore.Address.Country); Console.WriteLine(bookStore.Name); foreach (var item in bookStore.Books) { Console.WriteLine(item.Title); } Console.ReadKey();
这样就成功了。
3:autoMapper中的ConstructUsing。
我们想一次性的定义好所有的字段,我们就可以使用ConstructUsing来操作。
//配置 这里还是说将名称不同的变量之间进行映射。 //定义BookDto到第一作者(Author)的ContactInfo之间的映射。 var map = Mapper.CreateMap<BookDto,ContactInfo>(); map.ConstructUsing(s=>new ContactInfo { Blog = s.FirstAuthorBlog, Email = s.FirstAuthorEmail, Twitter=s.FirstAuthorTwitter }); //转换 BookDto dto=new BookDto() { FirstAuthorEmail = "1193451014@qq.com", FirstAuthorBlog="www.cnblogs.com/netxiaohui", }; ContactInfo contactInfo = Mapper.Map<ContactInfo>(dto); Console.WriteLine(contactInfo.Blog); Console.WriteLine(contactInfo.Email); Console.ReadKey();
4:验证配置是否有效,无效的话会抛出异常的,。
Mapper.AssertConfigurationIsValid();
这里的抛出异常(AutoMapperConfigurationException),我们别小看它,在他执行期间,AutoMapper会检查每个目标类型的属性,一对一的去匹配源中是否存在合适相等的类型。
5:使用忽略选项(Ignore())
情景:目标类型有个成员,不能完成转换,我们不想让其转换,可以这样配置。
//我们不想再转换的时候将Book的Title进行转换,可以将其忽略 Mapper.CreateMap<BookDto, Book>().ForMember(dest=>dest.Title,opt=>opt.Ignore());
错误:出现了和上次一样的错误。
“{"Missing type map configuration or unsupported mapping.\r\n\r\nMapping types:\r\nBookStoreDto -> BookStore\r\nAMapper.Class.BookStoreDto -> AMapper.Class.BookStore\r\n\r\nDestination path:\r\nBookStore\r\n\r\nSource value:\r\nAMapper.Class.BookStoreDto"}”
这个就是没有进行配置,就是说AutoMapper不知道你要如何去转换,后来才发现我写反了,应该先进行配置在转换。
就是错在了这里。
附件:
“呆河马” http://www.cnblogs.com/jobs2/p/3503990.html
“魔古先生” http://www.cnblogs.com/mushroom/p/4291975.html
标签:
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有
- 修改MySQL数据库字符集 2018-07-16
- 百度编辑器UEditor与UEditor 公式插件完整Demo 2018-06-23
- Nancy之基于Nancy.Owin的小Demo 2018-06-22
- 翻译:XtraDB/InnoDB中的AUTO_INCREMENT处理方式(已提交到Ma 2018-06-18
- mysql中set autocommit=0与start transaction区别 2018-06-17
IDC资讯: 主机资讯 注册资讯 托管资讯 vps资讯 网站建设
网站运营: 建站经验 策划盈利 搜索优化 网站推广 免费资源
网络编程: Asp.Net编程 Asp编程 Php编程 Xml编程 Access Mssql Mysql 其它
服务器技术: Web服务器 Ftp服务器 Mail服务器 Dns服务器 安全防护
软件技巧: 其它软件 Word Excel Powerpoint Ghost Vista QQ空间 QQ FlashGet 迅雷
网页制作: FrontPages Dreamweaver Javascript css photoshop fireworks Flash