automapper 遇到了一些实际问题。我想我已经找到了解决方案,但不确定如何实施。
基本上我正在使用带有 ResolveUsing 和 ConstructedBy 的自定义映射将参数传递给构造函数,我知道大多数人在 global.asax 中设置了一次然后忘记了它。
但问题是我的方法(在 wcf 上)将不同的参数传递给 ResolveUsing 的构造函数......
在我使用静态方法 Mapper.CreateMap 和 Mapper.Map 之前,当不同的请求通过方法(多用户)进入 wcf 服务时,它们似乎相互冲突。
在阅读了一些内容之后,我可以使用 CreateMap 和 Map 的实例版本,以便每个单独的请愿书都有自己的地图并可以传入自己的参数。
但我似乎无法找到如何做到这一点。谁能解释一下?我真的卡住了...
在此之前,我会一次又一次地收到重复的键错误,并且我在构造函数上输入了一个日志跟踪,看起来 1 个请愿书正在覆盖另一个请愿书 - 因此是 Mapper 的静态版本。
好吧,我希望我是正确的,但我找不到其他任何东西......
已编辑 - 我所拥有的一个例子
基本上所有映射都在正常工作,因为我在大多数情况下都使用 MapFrom。
然后我创建了一个我的解析器实例,我传入了一个 URL。我在传递它之前检查了 url 并且它是正确的。但是一旦它返回它就会返回错误的 URL。
我需要传入 URL 的原因是它有变量,所以我需要替换变量......基本上有 2 个 url,具体取决于办公室,我到处都有日志,我可以看到我传入的内容,但一次我把它传进去了——它不是我传入的那个,如果这有意义的话,这很奇怪!!
它是一个 WCF 服务,一个客户端调用该方法两次,传入 2 个不同的办公室,因此有 2 个不同的 URL。但它们总是返回相同的 URL。就像一个会话正在覆盖另一个...
我希望这是有道理的。
SalesPointResolver newSalesPointResolver = new SalesPointResolver(returnReservationUrl, reservationSite.ReservationUrl, startDate, endDate, officeCode);
Mapper.CreateMap<Models.Custom.House, DTO.House>()
.ForMember(dest => dest.Id, opt => opt.MapFrom(src => src.Id))
.ForMember(dest => dest.TaxIncluded,
opt => opt.MapFrom(src => src.Segments.FirstOrDefault().TaxIncluded))
.ForMember(dest => dest.TaxPercentage,
opt => opt.MapFrom(src => src.Segments.FirstOrDefault().TaxPercentage))
.ForMember(dest => dest.SalesPoints,
opt =>
opt.ResolveUsing(newSalesPointResolver))
;
发现失败的地方 - 但不知道为什么
请参阅我在代码中的注释。在构造函数中,urlTemplate 到达,我将它保存在一个私有变量中,然后在被覆盖的 ResolveCore 中它是别的东西:-)
我在那里放置了一些 log4net 日志,所以我可以看到发生了什么。
[Log]
public class SalesPointResolver : ValueResolver<Models.Custom.House, IList<DTO.SalesPoint>>
{
private readonly ILog log = LogManager.GetLogger(System.Reflection.MethodBase.GetCurrentMethod().DeclaringType);
private string urlTemplate;
public SalesPointResolver (bool returnReservationUrl, string urlTemplate, DateTime startDate, DateTime endDate, string officeCode)
{
this.urlTemplate = urlTemplate;
log.Error("passed in " + urlTemplate); // THIS IS PERFECT
log.Error("I am now " + this.urlTemplate); // THIS IS PERFECT
}
protected override IList<DTO.SalesPoint> ResolveCore(House source)
{
this.house = source;
log.Error("in resolveCore :" + this.urlTemplate); // THIS IS RETURNING THE WRONG VALUE
临时解决方案
我已经做了一个临时解决方案,但它真的很糟糕。我确信 automapper 可以做我正在尝试的事情,但我显然做错了什么。
基本上,我通过 LINQ 返回一组记录(这是我的来源),因此我在每条记录上输入了一个新字段,其中包含正确的 URL 模板。然后,我没有(通过构造函数)传入 url 模板,而是将它作为集合(源)上每条记录的属性提供......它工作得很好。
当然,这确实是补丁,并不理想,但它让我跑步。
我哪里错了?