请求/答复
通过请求/答复模式,请求发送方(客户端应用程序)将接受与请求相关的答复。这是默认的模式,因为它既支持传入操作(一个或多个参数传递到该操作中),也支持返回操作(该操作将返回一个或者多个输出值传回调用方) 请注意,除非指定其他基础消息模式,否则,即使服务操作返回void,也属于请求/答复消息交换。 操作的结果是:除非客户异步调用操作,否则客户端将停止处理,直到收到返回消息,即使该消息正常情况下为空也是如此。
缺点:如果执行操作需要很长时间,则会降低客户端性能和响应能力。
优点:响应消息中可以返回SOAP错误,这表明可能在通信或处理中发生了一些与服务有关的错误状况。
单向
如果WCF服务应用程序的客户端不必等待操作完成。并且不处理SOAP错误,则该操作可以指定单向消息模式。单向操作是客户端调用操作并在WCF将消息写入网络后继续进行处理的操作。通常这意味着,除非在出站消息中数据非常庞大,否则客户端几乎继续运行。若要为void的操作指定单向模式,请将IsOnlyWay属性设置为true,默认为false。注意:如果使用out和ref参数时,指定单向操作,就会引发异常
[OperationContract(IsOneWay=true)] void TestMethod(string strInput);
双工
双工模式的特点是:无论使用单向消息发送还是请求/响应消息发送方式。客户端和服务均能够独立的向对方发送消息。对于必须直接与客户端通讯或向消息交换的任意一方提供异步体验(包括类似于事件的行为)的服务来说,这种双向通信非常有用。由于存在与客户端通讯的附加机制,双向模式比请求/响应或单向模式要略微复杂。若要设计双工协定,必须先设计回调协定,并将该回调协定的类型分配给标记服务协定的ServiceContract属性的CallbackContract属性,若要实现双工模式,您必须创建第二个接口,该接口包含在客户端调用方法声明。
//服务端接口 public interface ICalculatorDuplexCallback { [OperationContract(IsOneWay = true)] void Equals(double result); [OperationContract(IsOneWay = true)] void Equation(string eqn); }
ICalculatorDuplexCallback callback = null;
//构造方法
callback = OperationContext.Current.GetCallbackChannel<ICalculatorDuplexCallback>();
//服务端调用接口方法
callback.Equation();
//客户端实现 public class CallbackHandler : ICalculatorDuplexCallback { public void Equals(double result) { Console.WriteLine("Result({0})", result); } public void Equation(string eqn) { Console.WriteLine("Equation({0})", eqn); } }
static void Main(string[] args)
{
// Construct InstanceContext to handle messages on callback interface
InstanceContext instanceContext = new InstanceContext(new CallbackHandler());
}
App.config配置文件 Bind方式为wsDualHttpBinding方式,此方式支持双工消息模式
<system.serviceModel> <bindings /> <client /> <services> <service name="WcfServiceLibrary2.CalculatorService" behaviorConfiguration="WcfServiceLibrary2.Service1Behavior"> <host> <baseAddresses> <add baseAddress="http://localhost:8731/Design_Time_Addresses/WcfServiceLibrary2/CalculatorService/" /> </baseAddresses> </host> <endpoint address="" binding="wsDualHttpBinding" contract="WcfServiceLibrary2.ICalculatorDuplex"> <identity> <dns value="localhost"/> </identity> </endpoint> <endpoint address="mex" binding="mexHttpBinding" contract="IMetadataExchange"/> </service> </services> <behaviors> <serviceBehaviors> <behavior name="WcfServiceLibrary2.Service1Behavior"> <serviceMetadata httpGetEnabled="True"/> <serviceDebug includeExceptionDetailInFaults="False" /> </behavior> </serviceBehaviors> </behaviors> </system.serviceModel>