0

我们有一个复杂的对象 User ,其中包含一堆其他对象的列表。

User
  List<User> Subordinates {get; set;}
  etc....

当我们运行代码时,一些属性出错是完全可以接受的,因为与数据库的连接已经关闭,我们没有得到说下属。

在 AutoMapper 中,尝试将 User 类映射到另一个类时出现错误。

所以下属属性中的错误是;

'((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 来忽略那些错误的属性。

4

1 回答 1

2

根本原因是数据被延迟加载到您的实体中,通常在using(var context = new MyDbContext())块内,并AutoMapper尝试将未加载的属性映射到上下文块之外,触发加载,因此System.ObjectDisposedException因为上下文已经被释放。

您需要做的不是忽略无法加载的属性,而是确保在映射之前正确加载所有属性。我建议您阅读本指南,它展示了如何将控制器、实体和 dbcontext 放入正确的层中。

于 2016-08-19T03:15:22.517 回答