将对象映射到同一类型的另一个对象是否有意义?

时间:2016-07-14 15:05:18

标签: c# wcf automapper

我正在使用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尺寸)

1 个答案:

答案 0 :(得分:1)

您目前的问题似乎是在完成数据处理之前您的数据库连接已关闭。

尝试使用

db.mainEntity.Include(i=>i.relatedtable).Include(i=>i.anotherRelatedtable)
在您查询所有相关实体时

不在序列化程序中对对象进行1对1复制的一个很好的理由是循环(在使用json-feeded组件之前,您可能已经解决了它们):

父亲有孩子,孩子有父亲,有孩子,有......溢出!