我们有一个复杂的对象用户,其中包含一堆其他对象的列表。
User
List<User> Subordinates {get; set;}
etc....
当我们运行代码时,某些属性出错是完全可以接受的,因为与数据库的连接已经关闭,我们没有得到说服的下属。
在AutoMapper中,我在尝试将User类映射到另一个类时遇到错误。
所以Subordinates属性中的错误是;
'((System.Data.Entity.DynamicProxies.User_26F7582000F06E0D5B307573194E69014E40D1C586E95D4E4932757C1F4DE360)((System.Data.Entity.DynamicProxies.WorkflowTask_DEDE69BC0D3CAFD0CCDA62406BC48A7A7CCBD5E8B13369FF5E761B64348A767C)thisTask).User).Subordinates' threw an exception of type 'System.ObjectDisposedException'
AutoMapper抛出的错误是;
{"Error mapping types.\r\n\r\nMapping types:\r\nWorkflowTask -> jsonTask\r\nDataRepository.WorkflowTask -> Tasks.Models.jsonTask\r\n\r\nType Map configuration:\r\nWorkflowTask -> jsonTask\r\nDataRepository.WorkflowTask -> Tasks.Models.jsonTask\r\n\r\nProperty:\r\nUser"}
然后在InnerException中;
{"Error mapping types.\r\n\r\nMapping types:\r\nUser -> jsonUser\r\nDataRepository.User -> Tasks.Models.jsonUser\r\n\r\nType Map configuration:\r\nUser -> jsonUser\r\nDataRepository.User -> Tasks.Models.jsonUser\r\n\r\nProperty:\r\nSubordinates"}
我只需要AutoMapper来忽略那些出错的属性。
答案 0 :(得分:2)
根本原因是数据延迟加载到您的实体中,通常在using(var context = new MyDbContext())
块内,AutoMapper
尝试将卸载的属性映射到上下文块之外,从而触发加载,因此{{因为上下文已经处理掉了。
您需要做的是 NOT 忽略无法加载的属性,但要确保在映射之前正确加载所有属性。我建议你阅读this guidance,它展示了如何将控制器,实体和dbcontext放入正确的层中。