- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我一直在阅读有关使用 NHibernate 和 AutoMapper 将 DTO 的实体 ID 转换为域的实体的 StackOverflow 帖子。肯定有很多关于它的信息,但每个人似乎都有不同的建议,其中许多建议完全使用不同的工具 ( ValueInjecter )。此外,我发现的很多信息都是几年前的。因此,我再次解决这个问题,希望能为我解决问题。
我有以下 DTO 类:
public class PlaylistDto
{
public Guid Id { get; set;
public Guid StreamId { get; set; }
public List<PlaylistItemDto> Items { get; set; }
}
和相应的域:
public class Playlist
{
public Guid Id { get; set;
public Stream Stream { get; set; }
// Use interfaces so NHibernate can inject with its own collection implementation.
public IList<PlaylistItem> Items { get; set; }
}
首先,我声明我打算将这两个实体相互映射:
Mapper.CreateMap<Playlist, PlaylistDto>().ReverseMap();
Mapper.CreateMap<PlaylistItem, PlaylistItemDto>().ReverseMap();
Mapper.CreateMap<Stream, StreamDto>().ReverseMap();
ReverseMap 让我可以轻松声明双向映射。
此时,我可以毫不费力地将 Playlist 成功转换为 PlaylistDto:
// Singular:
PlaylistDto playlistDto = Mapper.Map<Playlist, PlaylistDto>(playlist);
// Collection:
List<PlaylistDto> playlistDtos = Mapper.Map<List<Playlist>, List<PlaylistDto>>(playlists);
这很好用。不需要额外的代码。但是,当我尝试映射另一个方向时出现问题。
playlistDto 仅存储对其 Stream 的 ID 引用。如果我将 DTO 转换为域,如下所示:
Playlist playlist = Mapper.Map<PlaylistDto, Playlist>(playlistDto);
那么无论 playlistDto 的 StreamID 是什么,播放列表的 Stream 总是 null。
我想添加一个中间步骤,允许使用 Dto 的 entityId 通过 NHibernate 获取域的实体。
我没有使用 AutoMapper,我会通过以下方式实现:
playlist.Stream = StreamDao.Get(playlistDto.StreamId);
话虽如此,我有以下问题:
我看到的一些示例可能会解决我的问题:
Using AutoMapper to unflatten a DTO :
Mapper.CreateMap<Person, Domain.Person>()
.ForMember(dest => dest.Address, opt => opt.ResolveUsing( src => { return new Address() {Address1 = src.Address, City = src.City, State = src.State }; }))
AutoMapper map IdPost to Post :
public class Id2EntityConverter<TEntity> : ITypeConverter<int, TEntity> where TEntity : EntityBase
{
public Id2EntityConverter()
{
Repository = ObjectFactory.GetInstance<Repository<TEntity>>();
}
private IRepository<TEntity> Repository { get; set; }
public TEntity ConvertToEntity(int id)
{
var toReturn = Repository.Get(id);
return toReturn;
}
#region Implementation of ITypeConverter<int,TEntity>
public TEntity Convert(ResolutionContext context)
{
return ConvertToEntity((int)context.SourceValue);
}
#endregion
}
(there's more to this, but this is the gist of it)
感谢建议。谢谢!
最佳答案
Id2Entity 转换器是我们在一个非常大的项目中广泛使用的,它工作得很好。这里的技巧是您扫描所有实体并设置从 int 到您的类型的映射。如果您需要完整代码,请告诉我。
这是创建映射的类。
public class AutoMapperGlobalConfiguration : IGlobalConfiguration
{
private readonly IConfiguration _configuration;
public AutoMapperGlobalConfiguration(IConfiguration configuration)
{
_configuration = configuration;
}
private void RegisterAssembly(Assembly assembly)
{
//add all defined profiles
var query = assembly.GetExportedTypes()
.Where(x => x.CanBeCastTo(typeof(Profile)));
foreach (Type type in query)
{
var profile = ObjectFactory.GetInstance(type).As<Profile>();
_configuration.AddProfile(profile);
Mapper.AddProfile(profile);
}
}
public void Configure()
{
_configuration.RecognizePostfixes("Id");
var assemblies = AppDomain.CurrentDomain.GetAssemblies().Where(a => a.FullName.StartsWith("DM."));
//create maps for all Id2Entity converters
MapAllEntities(_configuration);
assemblies.Each(RegisterAssembly);
}
private static void MapAllEntities(IProfileExpression configuration)
{
//get all types from the domain assembly and create maps that
//convert int -> instance of the type using Id2EntityConverter
var openType = typeof(Id2EntityConverter<>);
var idType = typeof(int);
var persistentEntties = typeof(Domain.Entities).Assembly.GetTypes()
.Where(t => typeof(EntityBase).IsAssignableFrom(t))
.Select(t => new
{
EntityType = t,
ConverterType = openType.MakeGenericType(t)
});
foreach (var e in persistentEntties)
{
var map = configuration.CreateMap(idType, e.EntityType);
map.ConvertUsing(e.ConverterType);
}
}
}
关于c# - 通过 NHibernate 和 AutoMapper 将 DTO 的实体 ID 转换为域的实体,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17453722/
我正在尝试在两个对象列表之间进行映射。源类型具有类型为 A 的复杂属性。 ;目标类型是类型 A 的扁平子集加上源类型中的附加标量属性。 public class A { public int
Automapper 是否可以将平面对象映射到复杂的对象图? Mapper.CreateMap() 将 PersonDto.BirthCertificateFatherName 映射到 Person
我有类似 this. 的问题但是这个答案对我不起作用。 我正在做一个小项目。我有两个域模型(Post,Source): public class Post { public Post()
假设我在“消息”类上有一个“评论”属性。我还有 2 个类属性,它们具有“Body”属性。如果该类设置了任一类属性,我希望 AutoMapper 将 Body 属性投影到模型的 comment 属性中,
我是 AutoMapper 的新手,有一个我正在尝试解决的问题。 如果我有这样的源类: public class Membership { public int MembershipId {
我有一个场景,我想忽略基类中定义的类的某些属性。 我有一个这样的初始映射 Mapper.CreateMap() .Include()
如何覆盖 AutoMapper 用于给定属性的类型转换器? 例如,如果我有: public class Foo { public string Name { get; set; } } pub
我正在尝试使用 AutoMapper 将三个实体模型映射到一个 View 模型中。最终输出应该是一个递归类别树,其中包含类别中的产品。类别树正在运行,但 View 模型的 Products 属性为 n
我有一个 Student目的: public class Student { public int Id { get; set; } public string FirstName {
我有一个复杂的对象,如: public class BusinessUnit { public TradingDesk TradingDesk { get; } pub
假设我有这个类: public class Account { public int AccountID { get; set; } public Enterprise Enterpr
从概念上我发现 Automapper 非常有趣。然而,我正试图在上面烧伤(或加热)我的手指。有人可以帮我开始吗?我还不明白我可以从哪里开始。我会喜欢从头开始写一些代码(而不是使用其他人的样本)然后去做
我一直在尝试创建一个自动映射器自定义值解析器,但我似乎错过了一些设置步骤,因为它似乎永远找不到 public abstract class ValueResolver : IValueResolve
我正在尝试让 AutoMapper 为我们在 View 模型上本地化所有 DateTime 属性。我们在系统中的任何地方都使用 UTC 并将所有内容以 UTC 存储在数据库中,但我们希望自动将其转换为
我知道是 AutoMapper而不是 AutoMerge(r),而是…… 我已经开始使用 AutoMapper 并且需要映射 A -> B,并从 C 添加一些属性,以便 B 成为一种 A + C 的平
鉴于这些类,我如何映射它们的字典? public class TestClass { public string Name { get; set; } } public class TestC
我想自定义 AutoMapper 转换类型的方式,而不丢失 AutoMapper 已实现的功能。 我可以创建一个自定义 ITypeConverter实例,但我不知道如何调用默认行为。 Mapper.C
从存储过程返回的数据有 3 列重复数据: Name | Address | PhoneNumber | UniqueCol1 | UniqueCol2 理想情况下,我希望我的模型通过仅存储一次值并收集
当我使用 List 属性映射对象时,默认情况下 Automapper 会将目标对象的 list 属性设置为源对象的实例。 有没有办法让自动映射器创建一个新列表并复制项目但不复制列表实例? 我希望通过以
如果我有这组源类怎么办: namespace Source { class CA { public CB B { get; set; } } class
我是一名优秀的程序员,十分优秀!