ASP.NET Core MVC 从入门到精通之自动映射(二)

简介: ASP.NET Core MVC 从入门到精通之自动映射(二)

随着技术的发展,ASP.NET Core MVC也推出了好长时间,经过不断的版本更新迭代,已经越来越完善,本系列文章主要讲解ASP.NET Core MVC开发B/S系统过程中所涉及到的相关内容,适用于初学者,在校毕业生,或其他想从事ASP.NET Core MVC 系统开发的人员。

经过前几篇文章的讲解,初步了解ASP.NET Core MVC项目创建,启动运行,以及命名约定,创建控制器,视图,模型,接收参数,传递数据ViewData,ViewBag,路由,页面布局,wwwroot和客户端库,Razor语法,EnityFrameworkCore与数据库,HttpContext,Request,Response,Session,序列化,文件上传,自动映射等内容,今天继续讲解ASP.NET Core MVC 中自动映射第二部分等相关内容,仅供学习分享使用。

经过上一篇文章的讲解,已经对ASP.NET Core中进行自动映射,有了一个初步的了解,今天继续接着上一篇文章对自动映射的第二部分内容进行讲解。

字符替换

在实际开发中,如果映射源存在一些特殊字符【如:ë ,Ă等】,映射目标是正常的字符,则需要进行替换,才能映射。如下所示:

var configuration = new MapperConfiguration(c =>
{
    c.ReplaceMemberName("Ä", "A");
    c.ReplaceMemberName("í", "i");
    c.ReplaceMemberName("Airlina", "Airline");
});

进行以上配置之后,会自动将Äbc映射到Abc上,将íng映射到ing上,将AirlinaMark映射到AirlineMark上。

自动映射匹配前缀与后缀

数据源一般都会有固定的风格,如带有前缀,后缀等标识。那么如何将带前缀的属性映射到不带前缀的的属性上呢?

默认情况下,带前缀是无法自动映射的。如下错误示例,映射源有一个前缀s,映射目标没有,则无法进行自动映射。如下:

可以在映射匹配文件中,增加映射前缀RecognizePrefixes("s"),如下所示:

namespace DemoCoreMVC.Profiles
{
    public class AutomapProfile:Profile
    {
        public AutomapProfile()
        {
            RecognizePrefixes("s");
            SourceMemberNamingConvention = new LowerUnderscoreNamingConvention();
            DestinationMemberNamingConvention = new PascalCaseNamingConvention();
            //创建映射关系
            CreateMap<StudentViewModel, Student>();
        }
    }
}

经过前缀设置后,则可以进行自动映射,如下所示:

关于映射匹配前缀后缀设置,有以下几点需要注意:

  1. 一般前缀都是具有一定规律的设置,否则有些前缀a,有些前缀b,没有一定的规律,则无法完全匹配。
  2. 后缀通过RecognizePostfixes("s");设置即可,功能测试与前缀一致。
  3. 取消前缀设置ClearPrefixes();就是取消所有的前缀设置列表中设置的前缀。Automapper默认匹配了Get前缀,如果不需要可以清除。

映射控制(不常用)

使用ShouldMapField和ShouldMapProperty控制哪些属性和字段能够被映射

cfg.ShouldMapField = fi => false;
cfg.ShouldMapProperty = pi =>pi.GetMethod != null && (pi.GetMethod.IsPublic || pi.GetMethod.IsPrivate);

默认所有public的field和property都会被map,也会map private 的setter,但是不会map整个property都是internal/private的属性。

列表映射

在实际工作中,列表的应用场景还是比较多的,列表映射也比较常用。如下所示:

[HttpPost]
public IActionResult Add(StudentViewModel studentViewModel)
{
    var listStudents=new List<StudentViewModel>();
    listStudents.Add(studentViewModel);
    var students =  mapper.Map<List<StudentViewModel>,List< Student>>(listStudents);
    studentService.Adds(students);
    return View();
}

经过测试发现,只要映射了元素类型,列表可以自动映射。如下所示:

AutoMapper默认会自动映射以下类型:

  • IEnumerable
  • IEnumerable<T>
  • ICollection
  • ICollection<T>
  • IList
  • IList<T>
  • List<T>
  • Arrays

这几个集合之间可以相互映射,如:mapper.Map<Source[], IEnumerable<Destination>>(sources);

手动控制映射(不常用)

如果对于完全没有任何规律的映射,如何进行呢?如下两个映射数据类型:

映射源类型:

namespace DemoCoreMVC.ViewModels
{
    public class UserViewModel
    {
        public int UserId { get; set; }
        public string UserName { get; set; }
        public string Mail { get; set; }
    }
}

映射目标类型:

namespace DemoCoreMVC.Models
{
    public class User
    {
        public int Id { get; set; }
        public string Name { get; set; }
        public string Email { get; set; }
    }
}

需要手动配置映射属性列,如下所示:

public class AutomapProfile:Profile
{
    public AutomapProfile()
    {
        RecognizePrefixes("s");
        //RecognizePostfixes("s");
        SourceMemberNamingConvention = new LowerUnderscoreNamingConvention();
        DestinationMemberNamingConvention = new PascalCaseNamingConvention();
        //创建映射关系
        CreateMap<StudentViewModel, Student>();
        //ClearPrefixes();
        CreateMap<UserViewModel, User>()
            .ForMember(dest => dest.Id, opt => opt.MapFrom(source => source.UserId))
            .ForMember(dest => dest.Name, opt => opt.MapFrom(source => source.UserName))
            .ForMember(dest => dest.Email, opt => opt.MapFrom(source => source.Mail));
    }
}

映射示例

通过手动配置映射列后,就可以实现自动映射,如下所示:

public IActionResult Add(UserViewModel userViewModel)
{
    var user =  mapper.Map<UserViewModel,User>(userViewModel);
    return View();
}

手动映射测试结果如下:

注意:手动映射主要适用于属性完全不一致,没有前缀,后缀,任何规律可言的属性映射的情况,所以一般不太常用。

嵌套映射

对于复杂的嵌套类型,对象的属性可能是一个复杂引用类型对象。

映射源,其中属性User为类型为UserViewModel的引用类型。如下所示:

namespace DemoCoreMVC.ViewModels
{
    public class EmployeeViewModel
    {
        public int Id { get; set; }
        public UserViewModel User { get; set; }
    }
}

映射目标,其中属性Uer为类型为User的引用类型。如下所示:

namespace DemoCoreMVC.Models
{
    public class Employee
    {
        public int Id { get; set; }
        public User User { get; set; }
    }
}

如果要对应复杂的存在嵌套关系的对象进行映射,则需要对属性类型也进行创建映射关系。如下所示:

CreateMap<UserViewModel, User>()
    .ForMember(dest => dest.Id, opt => opt.MapFrom(source => source.UserId))
    .ForMember(dest => dest.Name, opt => opt.MapFrom(source => source.UserName))
    .ForMember(dest => dest.Email, opt => opt.MapFrom(source => source.Mail));
CreateMap<EmployeeViewModel,Employee>();

在控制器中调用,如下所示:

public IActionResult Add(UserViewModel userViewModel)
{
    EmployeeViewModel employeeViewModel = new EmployeeViewModel() { Id = 1, User = userViewModel };
    var employee = mapper.Map<EmployeeViewModel, Employee>(employeeViewModel);
    return View();
}

运行测试,如下所示:

以上就是ASP.NET Core MVC从入门到精通之自动映射的第二部分的全部内容。

大家也可以参考以下文章连接,讲解的更加详细:https://blog.csdn.net/catshitone/article/details/109840926

相关文章
|
2月前
|
开发框架 .NET 开发者
简化 ASP.NET Core 依赖注入(DI)注册-Scrutor
Scrutor 是一个简化 ASP.NET Core 应用程序中依赖注入(DI)注册过程的开源库,支持自动扫描和注册服务。通过简单的配置,开发者可以轻松地从指定程序集中筛选、注册服务,并设置其生命周期,同时支持服务装饰等高级功能。适用于大型项目,提高代码的可维护性和简洁性。仓库地址:&lt;https://github.com/khellang/Scrutor&gt;
61 5
|
4月前
|
存储 开发框架 JSON
ASP.NET Core OData 9 正式发布
【10月更文挑战第8天】Microsoft 在 2024 年 8 月 30 日宣布推出 ASP.NET Core OData 9,此版本与 .NET 8 的 OData 库保持一致,改进了数据编码以符合 OData 规范,并放弃了对旧版 .NET Framework 的支持,仅支持 .NET 8 及更高版本。新版本引入了更快的 JSON 编写器 `System.Text.UTF8JsonWriter`,优化了内存使用和序列化速度。
116 0
|
2月前
|
开发框架 算法 中间件
ASP.NET Core 中的速率限制中间件
在ASP.NET Core中,速率限制中间件用于控制客户端请求速率,防止服务器过载并提高安全性。通过`AddRateLimiter`注册服务,并配置不同策略如固定窗口、滑动窗口、令牌桶和并发限制。这些策略可在全局、控制器或动作级别应用,支持自定义响应处理。使用中间件`UseRateLimiter`启用限流功能,并可通过属性禁用特定控制器或动作的限流。这有助于有效保护API免受滥用和过载。 欢迎关注我的公众号:Net分享 (239字符)
64 1
|
3月前
|
开发框架 .NET C#
在 ASP.NET Core 中创建 gRPC 客户端和服务器
本文介绍了如何使用 gRPC 框架搭建一个简单的“Hello World”示例。首先创建了一个名为 GrpcDemo 的解决方案,其中包含一个 gRPC 服务端项目 GrpcServer 和一个客户端项目 GrpcClient。服务端通过定义 `greeter.proto` 文件中的服务和消息类型,实现了一个简单的问候服务 `GreeterService`。客户端则通过 gRPC 客户端库连接到服务端并调用其 `SayHello` 方法,展示了 gRPC 在 C# 中的基本使用方法。
65 5
在 ASP.NET Core 中创建 gRPC 客户端和服务器
|
2月前
|
开发框架 缓存 .NET
GraphQL 与 ASP.NET Core 集成:从入门到精通
本文详细介绍了如何在ASP.NET Core中集成GraphQL,包括安装必要的NuGet包、创建GraphQL Schema、配置GraphQL服务等步骤。同时,文章还探讨了常见问题及其解决方法,如处理复杂查询、错误处理、性能优化和实现认证授权等,旨在帮助开发者构建灵活且高效的API。
59 3
|
4月前
mcr.microsoft.com/dotnet/core/aspnet:2.1安装libgdiplus
mcr.microsoft.com/dotnet/core/aspnet:2.1安装libgdiplus
45 1
|
5月前
|
开发框架 监控 前端开发
在 ASP.NET Core Web API 中使用操作筛选器统一处理通用操作
【9月更文挑战第27天】操作筛选器是ASP.NET Core MVC和Web API中的一种过滤器,可在操作方法执行前后运行代码,适用于日志记录、性能监控和验证等场景。通过实现`IActionFilter`接口的`OnActionExecuting`和`OnActionExecuted`方法,可以统一处理日志、验证及异常。创建并注册自定义筛选器类,能提升代码的可维护性和复用性。
|
5月前
|
开发框架 .NET 中间件
ASP.NET Core Web 开发浅谈
本文介绍ASP.NET Core,一个轻量级、开源的跨平台框架,专为构建高性能Web应用设计。通过简单步骤,你将学会创建首个Web应用。文章还深入探讨了路由配置、依赖注入及安全性配置等常见问题,并提供了实用示例代码以助于理解与避免错误,帮助开发者更好地掌握ASP.NET Core的核心概念。
142 3
|
4月前
|
开发框架 JavaScript 前端开发
一个适用于 ASP.NET Core 的轻量级插件框架
一个适用于 ASP.NET Core 的轻量级插件框架
|
5月前
|
存储 开发框架 前端开发
ASP.NET MVC 迅速集成 SignalR
ASP.NET MVC 迅速集成 SignalR
114 0

热门文章

最新文章