WCF服务-向后兼容性问题
我只是开始创建一些WCF服务,但我要求使它们向后兼容旧版(.NET 1.1和2.0)客户端应用程序。
我设法使服务能够在3.0和更高版本的客户端上正确运行,但是当我使用basicHttpBinding端点发布该服务时(我认为这是实现兼容性所必需的),该服务将重构我的方法签名。例如
public bool MethodToReturnTrue(string seedValue);
在客户端应用中显示为
public void MethodToReturnTrue(string seedValue, out bool result, out bool MethodToReturnTrueResultSpecified);
我已经尝试过在我的自托管控制台应用程序的app.config中想到的每个配置参数,但似乎无法实现此功能。我想这可能导致我的期望有缺陷的事实,但是令我惊讶的是WCF服务无法处理下级客户端的布尔返回类型。
我当前的app.config看起来像这样。
<?xml version="1.0" encoding="utf-8" ?> <configuration> <system.serviceModel> <services> <service behaviorConfiguration="MyServiceTypeBehaviors" Name="MyCompany.Services.CentreService.CentreService"> <clear /> <endpoint address="http://localhost:8080/CSMEX" binding="basicHttpBinding" bindingConfiguration="" contract="IMetadataExchange" /> <endpoint address="http://localhost:8080/CentreService" binding="basicHttpBinding" bindingName="Compatible" name="basicEndpoint" contract="MyCompany.Services.CentreService.ICentreService" /> </service> </services> <behaviors> <serviceBehaviors> <behavior name="MyServiceTypeBehaviors" > <serviceMetadata httpGetEnabled="true" /> </behavior> </serviceBehaviors> </behaviors> </system.serviceModel> </configuration>
有人可以建议吗?
解决方案
回答
啊,这真杀了我!我大约3个月前在工作中做了此操作,现在我不记得所有细节了。
我确实记得,但是,我们需要basicHttpBinding,并且不能使用新的序列化器(这是默认的)。我们必须使用"旧的" XmlSerializer。
不幸的是,我不再在执行此操作的地方工作,因此无法查看代码。我会打电话给我的老板,看看有什么可以挖掘的。
回答
好的,我们需要在短期内解决此问题,因此我们想到了"互操作"或者兼容性层的概念。
Baiscally,我们所做的只是在项目中添加了传统的ASMX Web服务,并使用本机WCF调用从中调用了WCF服务。这样,我们就可以将适当的类型返回给客户端应用程序,而无需进行大量的重构工作。我知道这是一个骇人听闻的解决方案,但这是我们拥有如此庞大的旧版代码库的最佳选择。而且,额外的好处是它实际上工作得非常好。 :)
回答
我们必须使用XmlSerializer。例如:
[ServiceContract(Namespace="CentreServiceNamespace")] [XmlSerializerFormat(Style=OperationFormatStyle.Document, SupportFaults=true, Use=OperationFormatUse.Literal)] public interface ICentreService { [OperationContract(Action="CentreServiceNamespace/MethodToReturnTrue")] bool MethodToReturnTrue(string seedValue); }
我们必须手动设置操作操作名称,因为自动生成的WCF名称的构造与ASMX操作名称不同(WCF也包括接口名称,而ASMX不包括)。
我们使用的所有数据合同都应使用[XmlType]装饰,而不是[DataContract]装饰。
配置文件不需要更改。