ASP.NET Core Web中使用AutoMapper進(jìn)行對(duì)象映射
前言
在日常開(kāi)發(fā)中,我們常常需要將一個(gè)對(duì)象映射到另一個(gè)對(duì)象,這個(gè)過(guò)程中可能需要編寫(xiě)大量的重復(fù)性代碼,如果每次都手動(dòng)編寫(xiě),不僅會(huì)影響開(kāi)發(fā)效率,而且當(dāng)項(xiàng)目越來(lái)越復(fù)雜、龐大的時(shí)候還容易出現(xiàn)錯(cuò)誤。為了解決這個(gè)問(wèn)題,對(duì)象映射庫(kù)就隨之而出了,這些庫(kù)可以自動(dòng)完成對(duì)象之間的映射,從而減少大量的開(kāi)發(fā)工作量,提高開(kāi)發(fā)工作效率。今天我們來(lái)講講在ASP.NET Core Web中使用AutoMapper快速進(jìn)行對(duì)象映射。
使用對(duì)象映射庫(kù)有哪些好處?
- 減少開(kāi)發(fā)工作量,提高開(kāi)發(fā)效率。
 - 減少開(kāi)發(fā)過(guò)程中的錯(cuò)誤和bug。
 - 簡(jiǎn)化代碼結(jié)構(gòu),提高代碼可讀性和可維護(hù)性。
 
AutoMapper對(duì)象映射庫(kù)介紹
AutoMapper是一個(gè)簡(jiǎn)單易用的.NET對(duì)象映射庫(kù),用于快速、方便地進(jìn)行對(duì)象之間的轉(zhuǎn)換和映射,極大的簡(jiǎn)化了開(kāi)發(fā)人員在處理對(duì)象映射時(shí)的工作量。
- GitHub開(kāi)源地址:https://github.com/AutoMapper/AutoMapper
 - 在線文檔地址:https://docs.automapper.org/en/stable/Getting-started.html
 
安裝AutoMapper NuGet包
在ASP.NET Core Web API項(xiàng)目中搜索:AutoMapper NuGet包安裝。
圖片
創(chuàng)建源對(duì)象和目標(biāo)對(duì)象
接下來(lái)我們分別定義一個(gè)源對(duì)象(Student)和一個(gè)目標(biāo)對(duì)象(StudentViewModel)。
Student(源對(duì)象)
public class Student
    {
        /// <summary>
        /// 學(xué)生ID [主鍵,自動(dòng)遞增]
        /// </summary>
        [PrimaryKey, AutoIncrement]
        [Display(Name = "學(xué)生ID")]
        public int StudentID { get; set; }
        /// <summary>
        /// 班級(jí)ID
        /// </summary>
        [Display(Name = "班級(jí)ID")]
        public int ClassID { get; set; }
        /// <summary>
        /// 學(xué)生姓名
        /// </summary>
        [Display(Name = "學(xué)生姓名")]
        public string Name { get; set; }
        /// <summary>
        /// 學(xué)生年齡
        /// </summary>
        [Display(Name = "學(xué)生年齡")]
        public int Age { get; set; }
        /// <summary>
        /// 學(xué)生性別
        /// </summary>
        [Display(Name = "學(xué)生性別")]
        public string Gender { get; set; }
    }StudentViewModel(目標(biāo)對(duì)象)
public class StudentViewModel
    {
        /// <summary>
        /// 學(xué)生ID [主鍵,自動(dòng)遞增]
        /// </summary>
        [PrimaryKey, AutoIncrement]
        [Display(Name = "學(xué)生ID")]
        public int StudentID { get; set; }
        /// <summary>
        /// 班級(jí)ID
        /// </summary>
        [Display(Name = "班級(jí)ID")]
        public int ClassID { get; set; }
        /// <summary>
        /// 學(xué)生姓名
        /// </summary>
        [Display(Name = "學(xué)生姓名")]
        public string Name { get; set; }
        /// <summary>
        /// 學(xué)生年齡
        /// </summary>
        [Display(Name = "學(xué)生年齡")]
        public int Age { get; set; }
        /// <summary>
        /// 學(xué)生性別
        /// </summary>
        [Display(Name = "學(xué)生性別")]
        public string Gender { get; set; }
        /// <summary>
        /// 班級(jí)名稱(chēng)
        /// </summary>
        [Display(Name = "班級(jí)名稱(chēng)")]
        public string ClassName { get; set; }
    }配置AutoMapper映射規(guī)則
我們可以定義一個(gè)AutoMapperMappingProfile的映射配置文件,并在其中定義源類(lèi)型和目標(biāo)類(lèi)型之間的映射關(guān)系。
using AutoMapper;
using Entity;
using Entity.ViewModel;
namespace WebApi
{
    /// <summary>
    /// AutoMapper映射配置文件
    /// </summary>
    public class AutoMapperMappingProfile : Profile
    {
        /// <summary>
        /// 添加映射規(guī)則
        /// </summary>
        public AutoMapperMappingProfile()
        {
            CreateMap<Student, StudentViewModel>();
        }
    }
}Program中注冊(cè)AutoMapper服務(wù)
使用AddAutoMapper()方法可以將AutoMapper所需的服務(wù)添加到該集合中,以便在應(yīng)用程序的其他部分中使用。該方法需要傳入一個(gè)Assembly數(shù)組,以告訴AutoMapper要掃描哪些程序集來(lái)查找映射配置(在當(dāng)前作用域的所有程序集里面掃描AutoMapper的配置文件)。
public static void Main(string[] args)
        {
            var builder = WebApplication.CreateBuilder(args);
            builder.Services.AddControllers();
            //添加 AutoMapper 的配置
            //使用AddAutoMapper()方法可以將AutoMapper所需的服務(wù)添加到該集合中,以便在應(yīng)用程序的其他部分中使用。
            //該方法需要傳入一個(gè)Assembly數(shù)組,以告訴AutoMapper要掃描哪些程序集來(lái)查找映射配置(在當(dāng)前作用域的所有程序集里面掃描AutoMapper的配置文件)。
            builder.Services.AddAutoMapper(AppDomain.CurrentDomain.GetAssemblies());
        }進(jìn)行對(duì)象映射操作
依賴(lài)注入獲取IMapper接口的實(shí)例
/// <summary>
    /// 學(xué)生管理
    /// </summary>
    [ApiController]
    [Route("api/[controller]/[action]")]
    public class StudentController : ControllerBase
    {
        private readonly IMapper _mapper;
        /// <summary>
        /// 依賴(lài)注入
        /// </summary>
        /// <param name="mapper">mapper</param>
        public StudentController(IMapper mapper)
        {
            _mapper = mapper;
        }
    }進(jìn)行對(duì)象映射操作
接下來(lái)我們使用使用IMapper接口的Map方法來(lái)進(jìn)行對(duì)象映射操作。
var studentsListDto = _mapper.Map<List<StudentViewModel>>(students);映射結(jié)果輸出
圖片
完整示例源代碼
- https://github.com/YSGStudyHards/EasySQLite
 















                        
					    
 
 
 


 
 
 
 