我正在使用Entity Framework 6并将我的查询结果从WCF服务中发送出去。如果我尝试发送查询返回的实体,由于动态代理,我会收到异常。
我之前的解决方法是使用这样的代码......
return PatientServiceLogic.GetAll()
.Select(p => new Patient {
ID = p.ID,
FirstName = p.FirstName,
Surname = p.Surname,
AccidentDate = p.AccidentDate
})
.ToList();
这是一个简化的例子。可以想象,当对象图增长时,这可能会非常痛苦。
我刚刚发现了AutoMapper,看起来它会省去很多样板代码。当我想发送一组Patient对象(将在客户端应用程序的网格中使用)时,我不想要完整的Patient对象图,我想要一个简化的扁平版本。为此,PatientDto课程没问题。
但是,假设我做想要发送完整的对象图。我没有看到创建Patient类的碳副本和所有相关类的任何意义,然后将其复制到另一个,只是为了能够将它们发送出去。重用EF生成的类并将Patient对象映射到新的Patient对象会更有意义,该对象(在代码中创建,而不是EF)没有动态代理。这基本上就是我上面的代码所做的。
我尝试了这个,但是我得到了无用且非描述性的例外情况。
任何评论?这甚至是一件明智的事吗?如果没有,处理这种情况的最佳方式是什么?
当我尝试使用MapperConfiguration(c => c.CreateMap<Patient, Patient>())
设置的映射来调用服务时,我从WCF测试客户端获得了异常
接收到http://localhost:5448/PatientsService.svc的HTTP响应时发生错误。这可能是由于服务端点绑定不使用HTTP协议。这也可能是由于服务器中止HTTP请求上下文(可能是由于服务关闭)。有关详细信息,请参阅服务器日志。
服务器堆栈跟踪:
在 System.ServiceModel.Channels.HttpChannelUtilities.ProcessGetResponseWebException(引发WebException webException,HttpWebRequest请求,HttpAbortReason abortReason)
在 System.ServiceModel.Channels.HttpChannelFactory`1.HttpRequestChannel.HttpChannelRequest.WaitForReply(时间跨度 超时)at System.ServiceModel.Channels.RequestChannel.Request(消息消息, TimeSpan超时)at System.ServiceModel.Dispatcher.RequestChannelBinder.Request(消息 消息,TimeSpan超时)at System.ServiceModel.Channels.ServiceChannel.Call(String action, Boolean oneway,ProxyOperationRuntime操作,Object [] ins, 对象[]出局,TimeSpan超时)at System.ServiceModel.Channels.ServiceChannelProxy.InvokeService(IMethodCallMessage methodCall,ProxyOperationRuntime operation)at System.ServiceModel.Channels.ServiceChannelProxy.Invoke(即时聊天 消息)在[0]处重新抛出异常:at System.Runtime.Remoting.Proxies.RealProxy.HandleReturnMessage(即时聊天 reqMsg,IMessage retMsg)at System.Runtime.Remoting.Proxies.RealProxy.PrivateInvoke(MessageData&安培; 来自PatientsService.GetPatients()的msgData,Int32类型 PatientsServiceClient.GetPatients()
内部例外:
基础连接已关闭:发生意外错误 收到。在System.Net.HttpWebRequest.GetResponse()处 System.ServiceModel.Channels.HttpChannelFactory`1.HttpRequestChannel.HttpChannelRequest.WaitForReply(时间跨度 超时)
内部例外:
无法从传输连接中读取数据:现有数据 连接被远程主机强行关闭。在 System.Net.Sockets.NetworkStream.Read(Byte []缓冲区,Int32偏移量, 在System.Net.PooledStream.Read(Byte []缓冲区,Int32中的Int32大小) offset,Int32 size)at System.Net.Connection.SyncRead(HttpWebRequest请求,布尔值 userRetrievedStream,Boolean probeRead)
内部例外:
现有连接被远程主机强行关闭 System.Net.Sockets.Socket.Receive(Byte []缓冲区,Int32偏移量,Int32 size,SocketFlags socketFlags)at System.Net.Sockets.NetworkStream.Read(Byte []缓冲区,Int32偏移量, Int32尺寸)
答案 0 :(得分:1)
您目前的问题似乎是在完成数据处理之前您的数据库连接已关闭。
尝试使用
db.mainEntity.Include(i=>i.relatedtable).Include(i=>i.anotherRelatedtable)
在您查询所有相关实体时。
不在序列化程序中对对象进行1对1复制的一个很好的理由是循环(在使用json-feeded组件之前,您可能已经解决了它们):
父亲有孩子,孩子有父亲,有孩子,有......溢出!