16

我正在开发一个必须支持向后兼容性的客户端-服务器应用程序(.NET 4 WPF、WCF)。换句话说,就操作合约和数据合约而言,旧客户端应该与新服务器兼容(反之亦然)。

我们的 WCF 服务托管在 IIS 中,它们设置为使用 basicHttpBinding:

<basicHttpBinding>
   <binding name="basicHttpBinding_Configuration" maxBufferSize="2147483647"
      maxReceivedMessageSize="2147483647">
      <readerQuotas maxDepth="2147483647" maxStringContentLength="2147483647"
         maxArrayLength="2147483647" />
      <security mode="None" />
   </binding>
</basicHttpBinding>

...

<service behaviorConfiguration="SampleGateway.Data.DataAccessBehavior"
   name="SampleGateway.Data.DataAccess">
   <endpoint address="" binding="basicHttpBinding" bindingConfiguration="basicHttpBinding_Configuration"
      contract="Sample.Data.IDataAccess" />
      <endpoint address="mex" binding="mexHttpBinding" contract="IMetadataExchange" />
      <host>
      <baseAddresses>
         <add baseAddress="http://localhost:8731/Design_Time_Addresses/SampleGateway/SampleGateway.Data.DataAccess.svc" />
      </baseAddresses>
   </host>
</service>

...

<behavior name="SampleGateway.Data.DataAccessBehavior">
   <serviceMetadata httpGetEnabled="true" />
   <serviceDebug includeExceptionDetailInFaults="false" />
   <dataContractSerializer maxItemsInObjectGraph="2147483647" />
</behavior>

假设合同非常基本,看起来像这样:

[ServiceContract]
public interface IDataAccess
{
   [OperationContract]
   List<Data> GetData(List<int> ids, DateTime startDateTime, DateTime endDateTime);
}

最近,我发现我们可以将编码从 更改XMLbinary. 结合 IIS 压缩,这确实提高了我们的 WCF 方法(例如上面列出的 GetData)的性能。

此编码更改还需要更改客户端和服务器 WCF 绑定,从 a 切换basicHttpBindingcustomBinding.

<customBinding >
   <binding name="binaryHttpBinding_Configuration">
      <binaryMessageEncoding maxReadPoolSize="2147483647" maxSessionSize="2147483647" maxWritePoolSize="2147483647">
         <readerQuotas maxDepth="32" maxStringContentLength="2147483647" maxArrayLength="2147483647" maxBytesPerRead="4096" maxNameTableCharCount="2147483647"/>
      </binaryMessageEncoding>
      <httpTransport transferMode="Streamed" maxBufferPoolSize="2147483647" maxBufferSize="2147483647" maxReceivedMessageSize="2147483647" useDefaultWebProxy="true"/>
   </binding>
</customBinding>

...

<service behaviorConfiguration="SampleGateway.Data.DataAccessBehavior"
   name="SampleGateway.Data.DataAccess">
   <endpoint address="" binding="customBinding" bindingConfiguration="binaryHttpBinding_Configuration"
      contract="CEMLink.Data.IDataAccess" />
   <endpoint address="mex" binding="mexHttpBinding" contract="IMetadataExchange" />
   <host>
      <baseAddresses>
         <add baseAddress="http://localhost:8731/Design_Time_Addresses/SampleGateway/SampleGateway.Data.DataAccess.svc" />
      </baseAddresses>
   </host>
</service>

...

这就是问题所在。由于我们的软件必须支持客户端/服务器向后兼容,如果旧客户端basicHttpBinding尝试使用新客户端访问服务器customBinding,则调用将因不匹配而失败,例如"Content Type text/xml; charset=utf-8 was not supported by this service.... The client and service bindings may be mismatched"

我可以为同一个服务合同有两种绑定配置——一种是基本的,另一种是自定义的,它们都指向同一个接口?我该如何解决这个问题?

4

2 回答 2

17

对于在不同地址公开并与不同绑定对齐的相同服务,您基本上需要 2 个端点。 可能会对您有所帮助。

于 2013-06-20T06:58:02.013 回答
0

对于同一个服务合同,您可以有两个不同的绑定,但是您需要在配置中创建单独的服务节点,并且您还需要定义单独的端点。因此,为二进制格式的服务创建一个新端点,并让新版本的客户端引用它。

于 2013-06-19T21:33:46.727 回答