netcore使用AutoMapper
说明:以下是使用过程中看到的其他博主写的,地址如下:
地址一:https://cloud.tencent.com/developer/article/1395155
地址二:https://www.cnblogs.com/yanwuming/p/9609887.html
我的项目是netcore SDK2.2版本,开发软件vs2017;
首先告诉大家,很不幸的是:上面两种方法都试过了,但是都失败了,不知道是不是我自己哪里写错了,或者人品,或者状态不对吧,哎!欲哭无泪~~~~~ 而且我这边在使用的时候,提示已经弃用了,不知道有没有遇到跟我同样问题的朋友。
当时心里也是很不爽的,好吧,后面查阅资料,这样写就OK了:O(∩_∩)O哈哈~
services.AddAutoMapper(typeof(ServiceProfile));
ServiceProfile.cs是我写的一个测试类,继承Profile,代码如下:
public class ServiceProfile : Profile
{
public ServiceProfile()
{
CreateMap<OrderInfo, UserInfoDto>()
.ForMember(des=>des.UserName,opt=>opt.MapFrom(src=>src.Name))
.ForMember(des=>des.CreateTime,opt=>opt.MapFrom(src=>src.CreateTime.ToString("yyyy-MM-dd hh:mm:ss")))
;
}
}
有两个测试类实体OrderInfo和UserInfoDto,这两个就随便写了,大家可以自行测试!
最后,使用时如下:
private readonly IQueryBll queryBll;
private IMapper mapper;
public MongoQueryController(IQueryBll queryBll, IMapper mapper) { this.queryBll = queryBll;
this.mapper = mapper;
}
public IActionResult Index()
{
return View();
} [HttpGet]
[HttpPost]
public async Task<List<UserInfoDto>> QueryByName(string userName) {
if (string.IsNullOrEmpty(userName)) {
return new List<UserInfoDto>();
} var res = await this.queryBll.Query(userName);
return this.mapper.Map<List<OrderInfo>, List<UserInfoDto>>(res);
}
结果居然成功了:
数据库测试数据:
结果:
总结一下,就3步,不知道是不是新的版本更好使用了吗;
第一步:安装引用
install-package AutoMapper
install-package AutoMapper.Extensions.Microsoft.DependencyInjection
第二步:注册
在StartUp.cs 的ConfigureServices方法中注册:
services.AddAutoMapper(typeof(ServiceProfile)); //ServiceProfile为你Mapper的类
第三步:调用
属性/构造函数(测试过了,这两种调用都可以) 注入调用(如上实例)。
不知道大家发现没有,这样写还有一个弊端,就是,当有多个l类似ServiceProfile.cs时,我们难道要一个一个写吗?这样岂不是太累,而且容易忘记,应该有更好的方法,不过目前还没有写对,大家如果有好的建议感谢大家留言探讨;
上述“地址一”的大神其实写的就是那个意思了,反射找到Profile类型,但是我这边不知道怎么的没有成功,有好方法的希望大家一起探讨!
netcore使用AutoMapper的更多相关文章
- Asp.NetCore之AutoMapper进阶篇
应用场景 在上一篇文章--Asp.NetCore之AutoMapper基础篇中我们简单介绍了一些AutoMapper的基础用法以及如何在.NetCore中实现快速开发.我相信用过AutoMapper实 ...
- Asp.NetCore之AutoMapper基础篇
应用场景 现在由于前后端技术的分离,后端程序员在使用ORM框架开发后台API接口的时候,往往会将数据库的"数据模型"直接提供给前端.而大多数时候,可能这些数据并不能够满足前端展示的 ...
- .NetCore 使用AutoMapper
添加引用 AutoMapper AutoMapper.Extensions.Microsoft.DependencyInjection 注册服务 services.AddAutoMapper(); 配 ...
- AutoMapper在asp.netcore中的使用
# AutoMapper在asp.netcore中的使用 automapper 是.net 项目中针对模型之间转换映射的一个很好用的工具,不仅提高了开发的效率还使代码更加简洁,当然也是开源的,htt ...
- NetCore+AutoMapper多个对象映射到一个Dto对象
目录 一. 定义源映射类和被映射类DTO二.注入AutoMapper三.配置映射四.写测试 一.定义源映射对象 为了体现AutoMapper映射特性,在SocialAttribute中的Name属性没 ...
- NetCore AutoMapper的封装
需要引用AutoMapper的Nuget包 如果需要忽略某个字段就在字段上面打标签如下: [IgnoreMap] public string IgnoreValue { get; set; } ...
- netcore 2.2 封装 AutoMapper
在上篇中我们通过创建一个类并继承autoMapper的Profile类 public class Mappings : Profile { public Mappings() { CreateMap& ...
- netcore 2.2 使用 AutoMapper 实现实体之间映射
一.什么是AutoMapper? AutoMapper是一个简单的对象映射框架(OOM),将一个对象映射到另一个对象. 二.AutoMapper的好处 以前的时候我们将DTO对象转换为Model对象时 ...
- .NetCore学习笔记:四、AutoMapper对象映射
什么是AutoMapper?AutoMapper是一个简单的小型库,用于解决一个看似复杂的问题 - 摆脱将一个对象映射到另一个对象的代码.这种类型的代码是相当沉闷和无聊的写,所以为什么不发明一个工具来 ...
随机推荐
- 洛谷1387(基础二维dp)
题目很简单,数据也很小,但是思路不妨借鉴:dp[i][j]代表以(i,j)为右下角的最长正方形边长. 类比一维里面设“以XX为结尾的最XXX(所求)”. 另外define不要乱用!尤其这种min套mi ...
- Educational Codeforces Round 24 E
Vova again tries to play some computer card game. The rules of deck creation in this game are simple ...
- 高阶组件(Higher-Order Components)
有时候人们很喜欢造一些名字很吓人的名词,让人一听这个名词就觉得自己不可能学会,从而让人望而却步.但是其实这些名词背后所代表的东西其实很简单. 我不能说高阶组件就是这么一个东西.但是它是一个概念上很简单 ...
- css实现行内文字垂直居中
之前本人一直使用浮动.相对定位.绝对定位和display:table等css的方法进行定位.网上得知flex可实现弹性布局,符合未来发展趋势,随尝试. 1:让盒子行内文字垂直居中,解决思路是讲文字的行 ...
- qt read excel
void exceladapter::readfile(QString filename, QString sheetname, int colNo){ QSqlDatabase db = QSqlD ...
- monkeyrunner 简单用例编写
monkeyrunnerfrom com.android.monkeyrunner import MonkeyRunner,MonkeyDevice,MonkeyImagedevice = Monke ...
- [Windows Server 2012] 安装IIS8.5及FTP
★ 欢迎来到[护卫神·V课堂],网站地址:http://v.huweishen.com ★ 护卫神·V课堂 是护卫神旗下专业提供服务器教学视频的网站,每周更新视频. ★ 本节我们将带领大家:安装IIS ...
- Android安卓下拉阻尼效果实现原理及简单实例
原理 这种效果是通过自定义控件的方式来实现的,我自定义了一个控件类型,这个自定义控件(PullDownDumperLayout)继承自线性布局(LinearLayout). 用户可以下拉弹出的那个 ...
- mybatis中app的查询语句
SELECT * FROM ( SELECT (@rownum := @rownum + ) AS rownum,c.* FROM (SELECT @rownum := ) r, ( select * ...
- exit - 使程序正常中止
SYNOPSIS 总览 #include <stdlib.h> void exit(int status); DESCRIPTION 描述 函数 exit() 使得程序正常中止,statu ...