威尼斯人线上娱乐

配置AutoMapper映射规则,0开始展览对象映射

4 5月 , 2019  

近期察觉了3个比较风趣的东西
AutoMapper,首要将Model调换为DTO,DTO更尊重数量,对天地对象开展客观封装,从而不会将世界对象的一颦一笑过度揭穿给表现层。

先说说DTO

DTO是个什么样东东?

DTO(Data Transfer
Object)就是数码传输对象,说白了正是2个指标,只不过里边全是数额而已。

干什么要用DTO?

一、DTO更爱护数量,对世界对象开始展览客观封装,从而不会将世界对象的行为过度暴露给表现层

二、DTO是面向UI的急需而设计的,而世界模型是面向业务而布署的。由此DTO更适合于和显现层的竞相,通过DTO大家贯彻了显示层与天地Model之间的解耦,因而改造领域Model不会影响UI层

三、DTO说白了就是数额而已,不包蕴别的的事体逻辑,属于瘦腿型的靶子,使用时能够依靠区别的UI须要进行灵活的利用

 

先来看一些实例,七个类之间的投射。

AutoMapper

最近大家既然知道了使用DTO的益处,那么大家自然也想及时使用它,可是此地会拉扯四个标题:如何贯彻DTO和世界Model之间的更动?

有五个思路,大家依然本人写转换代码,要么选择工具。可是就动用来讲,作者依然认为用工具相比较轻便急速,那就接纳工具吧。其实这样的转变工具繁多,可是本人依旧调整利用AutoMapper,因为它充足轻量级,而且也很红,海外的大牌们都采用它。使用AutoMapper能够很方便的贯彻DTO和天地Model之间的转变,它是3个无敌的Object-Object
Mapping工具。

摘自让AutoMapper在您的品种里飞一会儿

配置AutoMapper映射规则

AutoMapper是基于约定的,因而在实用映射在此以前,我们要求先实行映射规则的配置。

public class Source
{
    public int SomeValue { get; set; }
    public string AnotherValue { get; set; }
}

public class Destination
{
    public int SomeValue { get; set; }
}

在上头的代码中,我们定义了五个类,大家需求将Source类的靶子映射到Destination类的对象方面。要到位那几个操作,大家需求对AutoMapper进行如下配置:

Mapper.CreateMap<Source, Destination>();

拓展一下测试:

Source src = new Source() { SomeValue = 1, AnotherValue = "2" };
Destination dest = Mapper.Map<Destination>(src);

ObjectDumper.Write(dest);

大家得以在调节台看到dest对象的属性值:

威尼斯人线上娱乐 1

那般大家就成功了2个轻易的AutoMapper映射。

第壹定义七个类Source与DTOSource:

AutoMapper6.2.2.0

AutoMapper陆.2.2.0与在此之前的本子有些分歧,那么终究有如何不一致,大家一齐来施行一下:

壹.首先,使用AutoMapper陆.二.二.0须要在您的门类中援引NuGet包,右键正视项,管理NuGet程序包,然后采纳浏览,寻找AutoMapper,安装,你就足以在等级次序中运用啊,你也得以在vs中运用展开工具-库程序包管理器-程序包管控平台,输入“Install-Package
AutoMapper”命令,就能够把AutoMapper增多到项目中了~

2.让大家初步运用

  (一)一个简便的照射

      首先,创制一个C#调节台应用程序,为了方便,大家在Program直接定义五个类:

      

public class Student
    {
        public string Name { get; set; }
        public int Sex { get; set; }
        public string Age { get; set; }
        public DateTime Birth { get; set; }
    }

    public class Dto_Student
    {
        public string n { get; set; }
        public string s { get; set; }
        public int a { get; set; }
        public string b { get; set; }
    }

    public class V_Student
    {
        public string Name { get; set; }
        public int Sex { get; set; }
        public string Age { get; set; }
        public DateTime Birth { get; set; }
    }

  (贰)多少个简短的映射,由于Student和V_Student类字段名称一致,类型同样,所以,映射能够那样写

  

//一个简单的映射
            AutoMapper.Mapper.Initialize(map => map.CreateMap<Student, V_Student>());
            var stu = AutoMapper.Mapper.Map<Student>(new V_Student
            {
                Name = "myname",
                Sex = 1,
                Age = "24",
                Birth = DateTime.Now
            });

            var vstu = AutoMapper.Mapper.Map<V_Student>(new Student
            {
                Name = "myname",
                Sex = 1,
                Age = "24",
                Birth = DateTime.Now
            });

  (三)那么,差别字段名称,乃至分裂档期的顺序的三个类怎样映射呢,那将要手动的酷炫相应字段了:

//属性不同名,属性类型不同映射
            AutoMapper.Mapper.Initialize(map => map.CreateMap<Student, Dto_Student>()
                .ForMember(d => d.n, opt =>
                {
                    opt.MapFrom(s => s.Name);
                })
                .ForMember(d => d.s, opt =>
                {
                    opt.MapFrom(s => s.Sex == 1 ? "男" : "女");
                })
                .ForMember(d => d.a, opt =>
                {
                    opt.MapFrom(s => Convert.ToInt32(s.Age));
                })
                .ForMember(d => d.b, opt =>
                {
                    opt.MapFrom(s => s.Birth.ToString("yyyy-MM-dd"));
                })
            );

            var dto_stu = AutoMapper.Mapper.Map<Dto_Student>(new Student
            {
                Name = "myname",
                Sex = 1,
                Age = "24",
                Birth = DateTime.Now
            });

            var stu = AutoMapper.Mapper.Map<Student>(new Dto_Student
            {
                n = "myname",
                s = "男",
                a = 24,
                b = DateTime.Now.ToString("yyyy-MM-dd")
            });

  那边一运营,发掘报错了,为何呢,原来是因为,由于映射字段类型不相同,无法反向映射,那么,怎么着再增加2个映射呢,那时候就需求利用Profile那一个类,大家须要三番五次那一个类,并在其间写下映射配置,具体如下:

配置AutoMapper映射规则,0开始展览对象映射。新建Dto_StudentProfile类和StudentProfile类:

public class Dto_StudentProfile:Profile
    {
        public Dto_StudentProfile()
        {
            base.CreateMap<Dto_Student, Student>()
                .ForMember(s => s.Name, opt =>
                {
                    opt.MapFrom(stu => stu.n);
                })
                .ForMember(s => s.Sex, opt =>
                {
                    opt.MapFrom(stu => stu.s.Equals("男")?1:0);
                })
                .ForMember(s => s.Age, opt =>
                {
                    opt.MapFrom(stu => stu.a.ToString());
                })
                .ForMember(s => s.Birth, opt =>
                {
                    opt.MapFrom(stu =>DateTime.Parse( stu.b+" 00:00:00"));
                });
        }
    }

public class StudentProfile:Profile
    {
        public StudentProfile()
        {
            base.CreateMap<Student, Dto_Student>()
                .ForMember(d => d.n, opt =>
                {
                    opt.MapFrom(stu => stu.Name);
                })
                .ForMember(d => d.s, opt =>
                {
                    opt.MapFrom(stu => stu.Sex == 1 ? "男" : "女");
                })
                .ForMember(d => d.a, opt =>
                {
                    opt.MapFrom(stu => Convert.ToInt32(stu.Age));
                })
                .ForMember(d => d.b, opt =>
                {
                    opt.MapFrom(stu => stu.Birth.ToString("yyyy-MM-dd"));
                });
        }
    }

  那么,我们如何接纳多个布局呢?

//配置映射
AutoMapper.Mapper.Initialize(map => map.AddProfiles(new[] {
    typeof(Dto_StudentProfile),
    typeof(StudentProfile)
}));
var dto_stu = AutoMapper.Mapper.Map<Dto_Student>(new Student
            {
                Name = "myname",
                Sex = 1,
                Age = "24",
                Birth = DateTime.Now
            });

            var stu = AutoMapper.Mapper.Map<Student>(new Dto_Student
            {
                n = "myname",
                s = "男",
                a = 24,
                b = DateTime.Now.ToString("yyyy-MM-dd")
            });

  这样,大家就到位了三个不相同字段名称,分化类型的照耀

(4)映射List<T>

  怎样进展实体列表的投射呢,其实,配置上并从未其他例外,只要求在选择上,换到list就足以了:

List<Student> estu = new List<Student>();
            estu.Add(new Student
            {
                Name = "myname",
                Sex = 1,
                Age = "24",
                Birth = DateTime.Now
            });
            estu.Add(new Student
            {
                Name = "myname",
                Sex = 1,
                Age = "24",
                Birth = DateTime.Now
            });
            List<Dto_Student> slist = AutoMapper.Mapper.Map<List<Student>, List<Dto_Student>>(estu);

  (5)你大概认为不太方便,那么,大家得以将AutoMapper的Initialize放到应用起来的时候运维

  Mvc项目,能够放置程序的Global中,假若是.NET Core
二.0的MVC项目,能够停放StartUp中运作:

威尼斯人线上娱乐 2

那边一直摘了前人的不贰秘诀,有意思味能够看一下

  (6)那么,你能够运用进行的办法实行映射,这里定义贰个AutoMapperHelper操作类:

using System;
using System.Collections;
using System.Collections.Generic;
using System.Text;

namespace AutoMapperTest
{
    public static class AutoMapperHelper
    {
        public static T MapTo<T>(this object obj)
        {
            if (obj == null) return default(T);
            return AutoMapper.Mapper.Map<T>(obj);
        }

        public static List<TDestination> MapToList<TDestination>(this object source)
        {
            return AutoMapper.Mapper.Map<List<TDestination>>(source);
        }
    }
}

  那样,你就可以那样使用:

List<Student> estu = new List<Student>();
            estu.Add(new Student
            {
                Name = "myname",
                Sex = 1,
                Age = "24",
                Birth = DateTime.Now
            });
            estu.Add(new Student
            {
                Name = "myname",
                Sex = 1,
                Age = "24",
                Birth = DateTime.Now
            });
            var slist = estu.MapToList<Dto_Student>();

  非list的实业映射也是同样的,这里不再多说,借使有哪些疑难,应接提出来,共同商量发展,谢谢您的开卷

 

 

Profile的用法

Profile提供了七个命名的映射类,全部继续自Profile类的子类都是1个炫人眼目会集。

我们来看一下Profile的用法,这几个例子中依然选择方面的Source类和Destination类。

public class SourceProfile : Profile
{
    protected override void Configure()
    {
        CreateMap<Source, Destination>();
    }
}

大家得以再Profile中重写Configure方法,从而成就映射规则的布置。从Profile早先化Mapper规则:

Mapper.Initialize(x => x.AddProfile<SourceProfile>());

在三个Profile中,大家得以成功七个、更复杂的平整的预订:

public class Destination2
{
    public int SomeValue { get; set; }
    public string AnotherValue2 { get; set; }
}

public class SourceProfile : Profile
{
    protected override void Configure()
    {
        //Source->Destination
        CreateMap<Source, Destination>();

        //Source->Destination2
        CreateMap<Source, Destination2>().ForMember(d => d.AnotherValue2, opt =>
        {
            opt.MapFrom(s => s.AnotherValue);
        });
    }
}

 

 1  public class Source
 2     {
 3         public int Id { get; set; }
 4         public string Content { get; set; }
 5     }
 6 
 7     public class DTOSource
 8     {
 9         public int Id { get; set; }
10         public string Content { get; set; }
11     }

AutoMapper最好施行

那段内容将研讨AutoMapper的规则写在如何地点的标题。

在上壹段中,大家已经清楚了什么样运用AutoMapper举行简短的对象映射,不过,在骨子里的类别中,我们会有很多类实行映射(从Entity转变为Dto,或然从Entity转变为ViewModel等),这么多的投射怎样协会将形成三个标题。

率先大家需求定义1个Configuration.cs的类,该类提供AutoMapper规则配置的进口,它只提供三个静态的诀窍,在程序第1遍运转的时候调用该办法成功布署。

当有七个Profile的时候,大家能够那样充足:

public class Configuration
{
    public static void Configure()
    {
        Mapper.Initialize(cfg =>
        {
            cfg.AddProfile<Profiles.SourceProfile>();
            cfg.AddProfile<Profiles.OrderProfile>();
            cfg.AddProfile<Profiles.CalendarEventProfile>();
        });
    }
}

在程序运转的时候,只须要调用Configure方法就能够。

摸底了那一个实现现在,我们能够再项目中增加AutoMapper文件夹,文件夹结构如下:

威尼斯人线上娱乐 3

Configuration为我们的静态配置入口类;Profiles文件夹为大家有着Profile类的公文夹。假设是MVC,大家需求在Global中调用:

AutoMapper.Configuration.Configure();

 Source与DTOSource字段完全同样,来看看它俩怎么着通过AutoMapper调换,代码很简短。

扁平化映射(Flattening)

默许景况下,大家的Source类和Destination类是依据属性名称进行相称映射的。除却,私下认可的绚烂规则还有上边三种意况,大家称为扁平化映射,即当Source类中不带有Destination类中的属性的时候,AutoMapper会将Destination类中的属性实行分割,或包容“Get”开端的措施,举个例子:

Order类:

public class Order
{
    public Customer Customer { get; set; }

    public decimal GetTotal()
    {
        return 100M;
    }
}

Order类中带有了叁个customer对象和三个GetTotal方法,为了便于演示,作者直接将GetTotal方法重临⑩0;

Customer类的概念如下:

public class Customer
{
    public string Name { get; set; }
}

OrderDto类的定义如下:

public class OrderDto
{
    public string CustomerName { get; set; }
    public string Total { get; set; }
}

大家在展开映射的时候,不需求举行相当的安顿,既能够做到从Order到OrderDto的投射。

public class OrderProfile : Profile
{
    protected override void Configure()
    {
        CreateMap<Entity.Order, Dto.OrderDto>();
    }
}

测试代码:

Entity.Customer customer = new Entity.Customer() { Name = "Tom" };
Entity.Order order = new Entity.Order() { Customer = customer };
Dto.OrderDto orderDto = Mapper.Map<Dto.OrderDto>(order);
ObjectDumper.Write(order, 2);
ObjectDumper.Write(orderDto);

测试结果:

威尼斯人线上娱乐 4

1 Mapper.Initialize(x=>{
2      x.CreateMap<Source,DTOSource>();
3 });
4 
5 Source s = new Source{Id=1,Content="123"};
6 
7 DTOSource dto = Mapper.Map<DTOSource>(s);

点名映射字段(Projection)

在实质上的业务情形中,大家的Source类和Destination类的字段不容许格外的协作,那一年大家就须要来钦命他们的莫过于映射关系,比如:

public class CalendarEvent
{
    public DateTime Date { get; set; }
    public string Title { get; set; }
}

public class CalendarEventForm
{
    public DateTime EventDate { get; set; }
    public int EventHour { get; set; }
    public int EventMinute { get; set; }
    public string DisplayTitle { get; set; }
}

在那多少个类中,Calendar伊夫nt的Date将被拆分为Calendar伊芙ntForm的日期、时、分七个字段,Title也将对应DisplayTitle字段,那么相应的Profile定义如下:

public class CalendarEventProfile : Profile
{
    protected override void Configure()
    {
        CreateMap<Entity.CalendarEvent, Entity.CalendarEventForm>()
            .ForMember(dest => dest.EventDate, opt => opt.MapFrom(src => src.Date.Date))
            .ForMember(dest => dest.EventHour, opt => opt.MapFrom(src => src.Date.Hour))
            .ForMember(dest => dest.EventMinute, opt => opt.MapFrom(src => src.Date.Minute))
            .ForMember(dest => dest.DisplayTitle, opt => opt.MapFrom(src => src.Title));
    }
}

测试代码:

Entity.CalendarEvent calendarEvent = new Entity.CalendarEvent()
{
    Date = DateTime.Now,
    Title = "Demo Event"
};
Entity.CalendarEventForm calendarEventForm = Mapper.Map<Entity.CalendarEventForm>(calendarEvent);
ObjectDumper.Write(calendarEventForm);

测试结果:

威尼斯人线上娱乐 5

第3步建立Source到DTOSource之间的照射,起头化多少个Source实例后,来看下实践结果:

注脚配置项(Configuration Validation)

AutoMapper提供了1种声明机制,用来判定Destination类中的全体属性是还是不是都被映射,假设存在未被映射的特性,则抛出1二分。

表达的用法:

Mapper.AssertConfigurationIsValid();

例如:

public class Source
{
    public int SomeValue { get; set; }
    public string AnotherValue { get; set; }
}

Destination代码:

public class Destination
{
    public int SomeValuefff { get; set; }
}

测试:

Mapper.CreateMap<Entity.Source, Entity.Destination>();
Mapper.AssertConfigurationIsValid();

威尼斯人线上娱乐 ,运维程序将会并发AutoMapperConfigurationException极度:

威尼斯人线上娱乐 6

那是因为SomeValuefff在Source类中绝非对号入座的字段变成的。

斩草除根那种万分的措施有:

钦赐映射字段,举例:

Mapper.CreateMap<Entity.Source, Entity.Destination>()
    .ForMember(dest => dest.SomeValuefff, opt =>
    {
        opt.MapFrom(src => src.SomeValue);
    });

抑或应用Ignore方法:

Mapper.CreateMap<Entity.Source, Entity.Destination>()
    .ForMember(dest => dest.SomeValuefff, opt =>
    {
        opt.Ignore();
    });

要么选用自定义解析器,自定义解析器在上面讲到。

威尼斯人线上娱乐 7

自定义解析器(Custom value resolvers)

AutoMapper允许我们自定义解析器来成功Source到Destination的值的调换。举例:

public class Source
{
    public int Value1 { get; set; }
    public int Value2 { get; set; }
}

public class Destination
{
    public int Total { get; set; }
}

Total属性在Source中不设有,倘使明天创建映射规则,在炫酷的时候明确会抛出尤其。这一年大家就供给利用自定义解析器来产生映射。

自定义解析器必要贯彻 IValueResolver 接口,接口的概念如下:

public interface IValueResolver
{
    ResolutionResult Resolve(ResolutionResult source);
}

大家来自定义1个Resolver:

public class CustomResolver : ValueResolver<Source, int>
{
    protected override int ResolveCore(Source source)
    {
        return source.Value1 + source.Value2;
    }
}

下一场在炫人眼目规则中使用这些解析器:

public class SourceProfile : Profile
{
    protected override void Configure()
    {
        //Source->Destination
        CreateMap<Source, Destination>()
            .ForMember(dest => dest.Total, opt =>
            {
                opt.ResolveUsing<CustomResolver>();
            });
    }
}

测试代码:

Source src = new Source()
{
    Value1 = 1,
    Value2 = 2
};
Destination dest = Mapper.Map<Destination>(src);
ObjectDumper.Write(dest);

测试结果:

威尼斯人线上娱乐 8

在行使自定义Resolver中,大家仍是能够钦命Resolver的构造函数,举例:

//Source->Destination
CreateMap<Source, Destination>()
    .ForMember(dest => dest.Total, opt =>
    {
        opt.ResolveUsing<CustomResolver>()
            .ConstructedBy(() => 

new CustomResolver

());
    });

实行到位后,可以看来dto中的数据与前面开始化的s的多寡是1律的,就如直接将s拷贝了壹份给dto,在五个类字段名定全同样的景况下那样,那么一旦DTOSource中的字段名与Source中的不均等如何,其实也很简短,只需

自定义类型转变器(Custom type converters)

AutoMapper通过ConvertUsing来利用自定义类型调换器。ConvertUsing有三种用法:

void ConvertUsing(Func<TSource, TDestination> mappingFunction);
void ConvertUsing(ITypeConverter<TSource, TDestination> converter);
void ConvertUsing<TTypeConverter>() where TTypeConverter : ITypeConverter<TSource, TDestination>;

当大家有如下的Source类和Destination类:

public class Source
{
    public string Value1 { get; set; }
}

public class Destination
{
    public int Value1 { get; set; }
}

小编们得以选拔如下配置:

public class SourceProfile : Profile
{
    protected override void Configure()
    {
        //string->int
        CreateMap<string, int>()
            .ConvertUsing(Convert.ToInt32);
        //Source->Destination
        CreateMap<Source, Destination>();
    }
}

在上头的配备中,大家第三创设了从string到int的类型调换,这里运用了系统自带的Convert.ToInt32转变方法。

除此而外那种格局之外,大家还足以自定义类型调换器:

public class CustomConverter : ITypeConverter<Source, Destination>
{
    public Destination Convert(ResolutionContext context)
    {
        Source src = context.SourceValue as Source;
        Destination dest = new Destination();
        dest.Value1 = System.Convert.ToInt32(src.Value1);

        return dest;
    }
}

透过那几个转换器,大家得以绕过string到int的转移,间接将Source类的靶子转换为Destination类的靶子。

相应的配备如下:

public class SourceProfile : Profile
{
    protected override void Configure()
    {
        //Source->Destination
        CreateMap<Source, Destination>()
            .ConvertUsing<CustomConverter>();
    }
}

只怕,大家也能够运用上面包车型客车布局:

public class SourceProfile : Profile
{
    protected override void Configure()
    {
        //Source->Destination
        CustomConverter converter = new CustomConverter();
        CreateMap<Source, Destination>()
            .ConvertUsing(converter);
    }
}

要改成一丝丝的代码既可:

空值替换(Null substitution)

空值替换允许大家将Source对象中的空值在转移为Destination的值的时候,使用钦定的值来替换空值。

public class Source
{
    public string Value { get; set; }
}

public class Destination
{
    public string Value { get; set; }
}

安顿代码:

public class SourceProfile : Profile
{
    protected override void Configure()
    {
        //Source->Destination
        CreateMap<Source, Destination>()
            .ForMember(dest => dest.Value, opt =>
            {
                opt.NullSubstitute("原始值为NULL");
            });
    }
}

测试代码:

Source src = new Source();
Destination dest = Mapper.Map<Destination>(src);
ObjectDumper.Write(dest);

测试结果:

威尼斯人线上娱乐 9

我们将DTOSource中的Content的字段名改成Desc,此时只供给树立映射关系时,内定字段就能够了:

标准映射(Conditional mapping)

标准映射只当Source类中的属性值满意一定原则的时候才举行映射。举例:

public class Foo
{
    public int baz;
}

public class Bar
{
    public uint baz;
}

相应的安插代码如下:

Mapper.CreateMap<Foo, Bar>()
    .ForMember(dest => dest.baz, opt =>
    {
        opt.Condition(src => (src.baz >= 0));
    });


转自:http://www.cnblogs.com/youring2/p/automapper.html
1 Mapper.Initialize(x => {
2    x.CreateMap<Source, DTOSource>().ForMember(c=>c.Desc,q=> {
3       q.MapFrom(z => z.Content);
4      });
5 });

来探望运维结果什么;

威尼斯人线上娱乐 10

能够看来与前边的周转结果是平等的。

那正是说什么样映射四个List,其实也异常粗略,和上述代码差不离可以说是逼真,只是在最终一步时,要做一小点的改换就能够了。如上边代码:

 1  Mapper.Initialize(x => {
 2                 x.CreateMap<Source, DTOSource>().ForMember(c => c.Desc, q =>
 3                 {
 4                     q.MapFrom(z => z.Content);
 5                 });
 6             });
 7 
 8             s.Add(new Source { Id = 1, Content = "123" });
 9 
10             var dto = Mapper.Map<List<DTOSource>>(s);

 

能够看出除了最终一句代码,其它差不多是完全同样的,只是在终极一句代码中,目的项目改成了List<DTOSource>仅此而已。看下运维结果怎么样:

威尼斯人线上娱乐 11

结果符合预期。

在实际上的项目中,那样的写法确定是不符合供给的,一般会做三个卷入,新建多少个SourceProfile承继自Profile:

1  public SourceProfile()
2         {
3             base.CreateMap<Source, DTOSource>().ForMember(c => c.Desc, q => {
4                 q.MapFrom(z => z.Content);
5             });
6         }

装有映射关系都足以写在那2个类里,只要求在先后开首化的时候调用二遍就足以了:

 1
Mapper.Initialize(x => { 
x.AddProfile<SourceProfile>();  }); 

博主使用的AutoMapper版本陆.一.一.0,因为AutoMapper在陆.0本未时移除了Profile中的Configure,所以与6.0版本以下写法有点差别,六.0之下版本写法为:

1 public class SourceProfile : Profile
2     {
3         protected override void Configure()
4         {
5             CreateMap<Source, DTOSource>().ForMember(c => c.Desc, q => {
6                 q.MapFrom(z => z.Content);
7             });
8         }
9     }

接轨Profile重写其Configure就可以,调用格局与上述未有太大差异。 Mapper.Initialize中可增多三个或四个Profile。

在MVC项目标施用中,能够将Mapper.Initialize封装到1个类里;

 public static class AutoMapperForMvc
    {
        public  static void Register()
        {
            Mapper.Initialize(x => {
                x.AddProfile<SourceProfile>();
            });
        }

    }

 进而在MVC的Global中进3回性注册:

 1 public class MvcApplication : System.Web.HttpApplication
 2     {
 3         protected void Application_Start()
 4         {
 5             AreaRegistration.RegisterAllAreas();
 6             FilterConfig.RegisterGlobalFilters(GlobalFilters.Filters);
 7             RouteConfig.RegisterRoutes(RouteTable.Routes);
 8             BundleConfig.RegisterBundles(BundleTable.Bundles);
 9             //注册
10             AutoMapperForMvc.Register();
11         }
12     }

 愈来愈多有意思的东西得以查阅官方网站


相关文章

发表评论

电子邮件地址不会被公开。 必填项已用*标注

网站地图xml地图