3

我真的遇到了一个障碍,试图通过 WCF 服务反序列化自定义对象列表。它使用.NET 4。我如何绕过不同的命名空间。我的 ASP.NET 应用程序在 3.5 上运行,并且参考设置正常。这可能是问题吗?我该如何解决?

我的服务是这样设置的:

合同

namespace MyDomain.Services.Report
{
   [ServiceContract(Name = "ICompanyReport")]
   public interface ICompanyReport
   {
       [OperationContract]
       byte[] GetFooReport(string fooName);
   }

   [Serializable]
   [DataContract(Name="FooReportRecord", Namespace="MyDomain.com"]
   public class FooReportRecord
   {
      [DataMember]
      public int ID {get; set;}
      [DataMember]
      public string Name {get; set;}
   }

}

服务端文件

public class CompanyReport: ICompanyReport
{
    public byte[] GetFooReport(string fooName)
    {
        var data = new List<FooReportRecord>();

        // get data based on fooName and populate data

        var ms = new MemoryStream();
        var bf = new BinaryFormatter();
        bf.Serialize(ms, data);
        return ms.ToArray();
    }
}

客户端:

var ls = proxy.GetFooReport("bar");
var bf = new BinaryFormatter();
var ms = new MemoryStream(ls);

// Unable to find assembly MyDomain.Services.Report error is thrown
var reportData = (List<FooReportRecord>)bf.Deserialize(ms);
4

1 回答 1

1

假设您的客户端是您的 .NET 3.5 应用程序并且 FooReportRecord 在您的 .NET 4 wcf 库中,您将收到编译时错误。

将 FooReportRecord 移动到在 .NET 3.5 中编译的第三类库,并从您的 WCF 应用程序和客户端 (ASP.NET) 中引用它

但正如@Phil 提到的,为什么不返回 FooReportRecord[] 而不是 byte[]

服务

public FooReportRecord[] GetFooReport(string fooName)
{
    var data = new List<FooReportRecord>();

    // get data based on fooName and populate data

    return data.ToArray();
}

客户

var proxy = new ServiceReference1.CompanyReportClient();
FooReportRecord[] ls = proxy.GetFooReport("bar");
于 2013-03-18T23:39:50.713 回答