1
所以我有一個移動服務運行良好,並希望添加DTOs的符號。 我使用AutoMapper在我的模型和DTO模型之間進行映射,但是數據庫的複雜性和結果我迫使我使用自定義解析器,而這又會引發空異常。自動映射器自定義解析器拋出空異常
具體 - 映射器初始化
Mapper.Initialize(cfg =>
{
cfg.CreateMap<Contact, MobileContact>()
.ForMember(mobcont => mobcont.Favorite, map => map.ResolveUsing<ContactResolver>());//.UseValue(true));//
cfg.CreateMap<MobileContact, Contact>();
});
而且我自定義的解析器是
public class ContactResolver : ValueResolver<Contact, bool>
{
protected override bool ResolveCore(Contact a)
{
return true;
}
}
編輯:最喜歡的當然是
的布爾如果我不使用自定義解析器和使用.UseValue(true)它工作得很好
儘管如上圖所示用自定義解析器一個共同的GET請求拋出以下異常:
Exception=System.NullReferenceException: Object reference not set to an instance of an object.
at AutoMapper.QueryableExtensions.Extensions.ResolveExpression(PropertyMap propertyMap, Type currentType, Expression instanceParameter)
at AutoMapper.QueryableExtensions.Extensions.CreateMemberBindings(IMappingEngine mappingEngine, TypePair typePair, TypeMap typeMap, Expression instanceParameter, IDictionary`2 typePairCount)
at AutoMapper.QueryableExtensions.Extensions.CreateMapExpression(IMappingEngine mappingEngine, TypePair typePair, Expression instanceParameter, IDictionary`2 typePairCount)
at AutoMapper.QueryableExtensions.Extensions.CreateMapExpression(IMappingEngine mappingEngine, TypePair typePair, IDictionary`2 typePairCount)
at AutoMapper.QueryableExtensions.Extensions.<>c__DisplayClass1`2.<CreateMapExpression>b__0(TypePair tp)
at System.Collections.Concurrent.ConcurrentDictionary`2.GetOrAdd(TKey key, Func`2 valueFactory)
at AutoMapper.Internal.DictionaryFactoryOverride.ConcurrentDictionaryImpl`2.GetOrAdd(TKey key, Func`2 valueFactory)
at AutoMapper.QueryableExtensions.Extensions.CreateMapExpression[TSource,TDestination](IMappingEngine mappingEngine)
at AutoMapper.QueryableExtensions.ProjectionExpression`1.To[TResult]()
at Microsoft.WindowsAzure.Mobile.Service.MappedEntityDomainManager`2.Query()
at azmobtestService.Models.MobileContactDomainManager.Query() in c:\Users\n.atlas\Source\Repos\JPhoneBook\Service\azmobtestService\Models\MobileContactDomainManager.cs:line 104
at Microsoft.WindowsAzure.Mobile.Service.TableController`1.Query(), Id=75849f58-ccb0-4a6b-8a77-491f13fcb717, Category='App.Controllers.Tables'
我用AutoMapper來映射een我的模型和DTOs模型,但數據庫的複雜性和我想要的結果迫使我使用自定義解析器,這反過來拋出空異常。 Ofcourse我不想把它設置爲true! 我想創建一個數據庫請求並搜索Favorites表中的一行並將其設置爲該值。正如您所看到的,此搜索基於用戶身份驗證(每個用戶每次聯繫我擁有多行最愛)。 – Nikatlas 2014-12-02 13:19:20
我編輯了一些應該可以工作的代碼,但我相信你必須做相當多的工作才能讓它按照你想要的方式工作。 – 2014-12-02 13:30:40
將配置更改爲: cfg.CreateMap()。ConvertUsing(new ContactToMobileContactTypeConverter()); cfg.CreateMap (); 並添加了您提供的代碼。 調試顯示轉換方法從未執行! 新的日誌是: LINQ to Entities不支持指定的類型成員'Id'。只支持初始化器,實體成員和實體導航屬性。更多更多 –
Nikatlas
2014-12-02 13:48:08