The article is a collection of most frequently asked questions about Windows Communication Foundation covering the beginner level.
What is WCF?
Microsoft refers to WCF as a programming platform that is used to build Service-oriented applications. Windows Communication Foundation is basically a unified programming model for developing, configuring and deploying distributed services. Microsoft has unified all its existing distributed application technologies (e.g. Microsoft Enterprise Services, ASMX web services, MSMQ, .NET Remoting, etc.) at one platform, i.e., WCF. Code name for WCF was Indigo.
Why to Use WCF? or What are the Advantages for Using WCF?
- Service Orientation is one of the key advantages of WCF. We can easily build service-oriented applications using WCF.
- If compared with ASMX web services, WCF service provides reliability and security with simplicity.
- As opposed to .NET Remoting, WCF services are interoperable.
- Different clients can interact with the same service using different communication mechanisms. This is achieved by using service endpoints. A single WCF service can have multiple endpoints. So, the developer will write code for service once and just by changing configuration (defining another service endpoint), it will be available for other clients as well.
- Extensibility is another key advantage of WCF. We can easily customize a service behavior if required.
What are the Core Components of WCF Service?
A WCF service has at least the following core components:
- Service Class: A service class implementing in any CLR-based language and expose at least one method
- Hosting Environment: A managed process for running service
- Endpoint: A client uses it to communicate with service
What is the Difference Between WCF and ASMX Web Services?
The basic difference is that ASMX web service is designed to send and receive messages using SOAP over HTTP only while WCF service can exchange messages using any format (SOAP is default) over any transport protocol (HTTP, TCP/IP, MSMQ, Named Pipes etc).
You can find a detailed discussion on WCF Vs ASMX Web services here.
What are the Endpoints in WCF? or Explain ABCs of Endpoint?
For WCF services to be consumed, it’s necessary that it must be exposed; Clients need information about service to communicate with it. This is where service endpoints play their role.
A service endpoint has three basic elements or also called ABCs of an endpoint, i.e., Address, Binding and Contract.
- Address: It defines "WHERE". Address is the URL that identifies the location of the service.
- Binding: It defines "HOW". Binding defines how the service can be accessed.
- Contract: It defines "WHAT". Contract identifies what is exposed by the service.
What is a WCF Binding? How Many Different Types of Bindings are Available in WCF?
Bindings in WCF actually define how to communicate with the service. Binding specifies what communication protocol as well as encoding method will be used. Optionally, binding can specify other important factors like transactions, reliable sessions and security.
Another WCF Tutorial gives more detailed understanding of Binding concept in WCF.
There are different built-in bindings available in WCF, each designed to fulfill some specific need.
basicHttpBinding
wsHttpBinding
netNamedPipeBinding
netTcpBinding
netPeerTcpBinding
netmsmqBinding
For details on different binding types, please follow the link to WCF bindings.
Can We Have Multiple Endpoints for Different Binding Types in Order to Serve Different Types of Clients?
Yes, we can have multiple endpoints for different binding types. For example, an endpoint with wsHttpBinding
and another one with netTcpBinging
.
What are the Hosting Options for WCF Services? Explain.
For a service to host, we need at least a managed process, a ServiceHost
instance and an Endpoint
configured. Possible approaches for hosting a service are:
- Hosting in a Managed Application/ Self Hosting
- Console Application
- Windows Application
- Windows Service
- Hosting on Web Server
- IIS 6.0 (ASP.NET Application supports only HTTP)
- Windows Process Activation Service (WAS) i.e. IIS 7.0 supports HTTP, TCP, NamedPipes, MSMQ
What are Contracts in WCF?
A Contract is basically an agreement between the two parties, i.e., Service and Client. In WCF, Contracts can be categorized as behavioral or structural.
- Behavioral Contracts define what operations client can perform on a service.
ServiceContract
attribute is used to mark a type as Service contract that contains operations. OperationContract
attributes is used to mark the operations that will be exposed. - Fault Contract defines what errors are raised by the service being exposed.
- Structural Contracts
DataContract
attribute define types that will be moved between the parties. MessageContract
attribute define the structure of SOAP message.
What Message Exchange Patterns are Supported by WCF?
- Request/Response
- One Way
- Duplex
Request/Response
It’s the default pattern. In this pattern, a response message will always be generated to the consumer when the operation is called, even with the void
return type. In this scenario, response will have empty SOAP body.
One Way
In some cases, we are interested to send a message to service in order to execute certain business functionality but not interested in receiving anything back. OneWay MEP will work in such scenarios. If we want queued message delivery, OneWay is the only available option.
Duplex
The Duplex MEP is basically a two-way message channel. In some cases, we want to send a message to service to initiate some longer-running processing and require a notification back from service in order to confirm that the requested process has been completed.
Related WCF Articles
CodeProject