AutoMapper文档:http://docs.automapper.org/en/stable/The-MyGet-build.html

新的版本抛弃了静态API方法,我们将使用依赖注入来完成。

①添加包

②创建MyAutoMapper.cs文件来创建实体和Dto之间的映射关系

 public class MyAutoMapper : Profile
{
public MyAutoMapper()
{
//实体和Dto的相互转化
CreateMap<PFUserDto, PFUser>().ReverseMap();
}
}
 /// <summary>
/// 用户表
/// </summary>
[Table("PF_User")]
public class PFUser
{ /// <summary>
/// 主键
/// </summary>
[Column("UserGuid")]
[Display(Name = "用户表主键", Description = "用户表主键")]
[DatabaseGenerated(DatabaseGeneratedOption.Identity)]
public Guid Id { get; set; } /// <summary>
/// 用户名
/// </summary>
[Display(Description = "用户名", Name = "用户名")]
[Column("UserName")]
[StringLength()]
public string UserName { get; set; } /// <summary>
/// 密码
/// </summary>
[Display(Description = "密码", Name = "密码")]
[Column("UserPassWord")]
[StringLength()]
public string UserPassWord { get; set; } /// <summary>
/// 是否删除
/// </summary>
[Display(Description = "是否删除", Name = "是否删除")]
[Column("IsDeleted")]
public byte? IsDeleted { get; set; } /// <summary>
/// 创建日期
/// </summary>
[Display(Description = "创建日期", Name = "创建日期")]
[Column("CreateDate")]
public DateTime? CreateDate { get; set; } }
 public class PFUserDto
{ /// <summary>
/// 主键
/// </summary>
[Column("UserGuid")]
[Display(Name = "用户表主键", Description = "用户表主键")]
[DatabaseGenerated(DatabaseGeneratedOption.Identity)]
public Guid Id { get; set; } /// <summary>
/// 用户名
/// </summary>
[Display(Description = "用户名", Name = "用户名")]
[Column("UserName")]
[StringLength(128)]
public string UserName { get; set; } /// <summary>
/// 密码
/// </summary>
[Display(Description = "密码", Name = "密码")]
[Column("UserPassWord")]
[StringLength(256)]
public string UserPassWord { get; set; } /// <summary>
/// 是否删除
/// </summary>
[Display(Description = "是否删除", Name = "是否删除")]
[Column("IsDelte")]
public byte? IsDeleted { get; set; } /// <summary>
/// 创建日期
/// </summary>
[Display(Description = "创建日期", Name = "创建日期")]
[Column("CreateDate")]
public DateTime? CreateDate { get; set; } public string MyProperty { get; set; } }

 

③添加服务

  

④使用:实体转Dto,Dto转实体也是一样的

ProjectTo<>方法:

值的转化,我们想给前端传的时间是字符串形式的,AutoMapper还允许我们自定义转化器来转化我们的数据类型

①创建DateTimeTypeConverter.cs文件

 /// <summary>
/// DateTime2string
/// </summary>
public class DateTimeTypeConverter : ITypeConverter<DateTime, string>
{
public string Convert(DateTime source, string destination, ResolutionContext context)
{
return source.ToString("yyyy-MM-dd HH:mm:ss");
}
}

添加类型映射关系

public class MyAutoMapper : Profile
{
public MyAutoMapper()
{
// 可以给lambda表达式
//CreateMap<DateTime, string>().ConvertUsing(x => x.ToString("yyyy-MM-dd HH:mm:ss"));
//实现接口
CreateMap<DateTime, string>().ConvertUsing<DateTimeTypeConverter>();
//实体和Dto的相互转化
CreateMap<PFUserDto, PFUser>().ReverseMap();
} }

修改我们的Dto  CreateDate类型

使用:字符串转时间

时间转字符串

还有别的就自己看文档吧

.net core使用AutoMapper的更多相关文章

  1. ASP.NET Core教程:ASP.NET Core使用AutoMapper

    一.前言 在实际的项目开发过程中,我们使用各种ORM框架可以使我们快捷的获取到数据,并且可以将获取到的数据绑定到对应的List<T>中,然后页面或者接口直接显示List<T>中 ...

  2. .net core中automapper的使用

    automapper 是将两个类中的相同字段进行映射,也可以指定字段进行映射:将 UserDao的id 映射为 User 的age CreateMap<UserDao, User>() . ...

  3. .net core启用 autoMapper

    启用 autoMapper   autoMapper 基于约定的对象映射器 目录 安装包 添加服务 书写映射关系 安装包   需要安装两个包:AutoMapper和AutoMapper.Extensi ...

  4. .Net Core使用AutoMapper做对象关系映射

    我想很多后端开发者,纠结于如何在Dto及表实体中做属性关系映射,因为真的太繁琐了., ⒈如何使用? Mapper.Initialize(cfg => cfg.CreateMap<Users ...

  5. .net Core 使用AutoMapper

    在我们的项目中慢慢的要把数据库的实体模型和视图模型进行分离,防止被人拿到我们表字段.在学校的时候自己只是有将很多数据库模型,写成一个视图模型返回到前台. 首先我们把这两个包引入项目中去. 然后我们创建 ...

  6. .NET Core应用框架AA介绍(二)

    AA的开源地址 https://github.com/ChengLab/AAFrameWork AA框架是一个基础应用框架,是建立在众多大家熟知的流行工具之上并与之集成.比如:ASP.NET Core ...

  7. Getting A Mime Type From A File Name In .NET Core

    Getting a mime type based on a file name (Or file extension), is one of those weird things you never ...

  8. 使用ASP.NET Core构建RESTful API的技术指南

    译者荐语:利用周末的时间,本人拜读了长沙.NET技术社区翻译的技术标准<微软RESTFul API指南>,打算按照步骤写一个完整的教程,后来无意中看到了这篇文章,与我要写的主题有不少相似之 ...

  9. 《进击吧!Blazor!》第一章 1.初识 Blazor

    作者介绍 陈超超 Ant Design Blazor 项目贡献者 拥有十多年从业经验,长期基于.Net技术栈进行架构与开发产品的工作,Ant Design Blazor 项目贡献者,现就职于正泰集团 ...

随机推荐

  1. 'while' statement cannot complete without throwing an exception

    You are probably using Android Studio or IntelliJ. If so, you can add this above your method contain ...

  2. winform子窗口与父窗口的交互-使用委托与事件

    实现子窗口与父窗口的交互,通过父窗口调用并控制子窗口,子窗口也能控制父窗口,使用委托和事件的方法,可以实现. 1.父窗口调用子窗口,并通过子窗口控制父窗口 新建工程,创建两个窗体    显示子窗体的代 ...

  3. windows通过秘钥使用ssh和scp

    windows10内置支持了ssh和scp等仿linux指令,可以让我们方便的使用类似linux的工作流把日常的代码资源部署维护工作写成脚本(批处理). ssh和scp都有-i参数可以通过指定一个私钥 ...

  4. MVC+Ninject+三层架构+代码生成 -- 总结(二、建項目)

    1.項目分層,其中SqlSugar 是一個ORM 庫類. 2.VS庫類 視圖.

  5. VS2008激活找不到密匙输入框

    VS2008试用版到期后会无法使用,网上一搜就能找到很多激活码: Visual Studio 2008 Professional Edition: XMQ2Y-4T3V6-XJ48Y-D3K2V-6C ...

  6. disconf的简单使用与远程配置更改为使用本地配置

    这几天因为阿里云迁移到腾讯云的原因,原来服务器上的disconf不再使用了.在这段时间里,系统出现的bug很难寻找原因(项目起不来),现在想要把disconf远程配置更改成直接使用本地配置.首先,了解 ...

  7. WPF控件介绍(2)

    上一章讲到了布局.这点就有点类似建筑设计.第一步是出图纸.整体的结构.而第二步就是堆砌, 建筑学里面也会有很多描述, 例如砖头,水泥.玻璃.瓷板.而在WPF中, 这一切的基础也就是控件.用于填充结构的 ...

  8. tkinter的trace()变动追踪

    tkinter的trace() 的参数w是写入追踪 from tkinter import * def callback(*args): xl.set(xE.get()) print("改变 ...

  9. VirtualBox安装Ubuntu-18.04-Server笔记

    准备 安装'Windows Terminal' 安装WSL 安装VirtualBox 安装 虚拟磁盘映像文件选择创建在SSD(如果有) 选择openssh,公钥从GitHub获取,前提是GitHub已 ...

  10. 简单实现Shiro单点登录(自定义Token令牌)

    1. MVC Controller 映射 sso 方法. /** * 单点登录(如已经登录,则直接跳转) * @param userCode 登录用户编码 * @param token 登录令牌,令牌 ...