In this WCF tutorial we introduce the primary reasons for moving from other technologies to WCF as well as how to get started using WCF. Prior to .Net 3.0 it was not an easy matter to select a particular technology for communicating between systems due to the number of technologies available from Microsoft. For example, users could have used Web Service to communicate between a Java based application and a .Net application; WSE users could have take advantage of some of the WS-* message protocols; MSMQ has the ability to queue messages which helps to communicate between intermittently connected solutions; Enterprise services (the successor of COM+) helps to build distributed application easily; .Net Remoting is a fast way to move messages between two .NET applications. All the above mentioned technologies have their pros and cons. Using WCF now we can take the advantage of all the above distributed technologies in a unified manner and WCF is the successor to all these message distribution technologies.
Performance comparison between distributed technologies:
When we migrate distributed applications made with ASP.NET Web Services, WSE, .NET Enterprise Services and .NET Remoting to WCF, it will in almost all cases result in a performance boost:
Other Distributed Technologies | WCF Performance Advantage |
ASP.NET Web Service | 25%—50% faster |
.NET Remoting | 25% faster |
WSE 2.0/3.0 implementations. | 400% faster |
.NET Enterprise Service | 100% faster subject to the load. |
Whereas the other Microsoft distributed technologies do not have too many limitations in running on Windows operating system, an application built with WCF can run only on Windows XP SP2, Windows Vista or Windows Server 2008.
In the next part of our WCF tutorial we take a more indepth look at WCF and how to get started using it.
PROGRAMMING MODEL
A WCF service is made up of three parts: the service, one or more endpoints and a hosting environment.
A service is basically a class written in a .Net compliant language which contains some methods that are exposed through the WCF service. A service may have one or more endpoints – an endpoint is responsible for communication from the service to the client.
Endpoints also have three parts which are known as ‘ABC’: ‘A’ for Address, ‘B’ for Binding and ‘C’ for Contracts.
Endpoints also have three parts which are known as ‘ABC’: ‘A’ for Address, ‘B’ for Binding and ‘C’ for Contracts.
Address: Address specifies the info about where to find the service.
Binding: Binding specifies the info for how to interact with the service.
Contracts: Contracts specifies the info for how the service is implemented and what it offers.
Finally a hosting environment where the service is contained.
WCF bindings: System-provided WCF bindings are used to specify the transport protocols, encoding, and security details required for clients and services to communicate with each other. As per MSDN followings are the system-provided WCF bindings:
< BasicHttpBinding: A binding that is suitable for communication with WS-Basic Profile conformant Web Services like ASMX-based services. This binding uses HTTP as the transport and Text/XML as the message encoding.
WSHttpBinding:
A secure and interoperable binding that is suitable for non-duplex service contracts.
A secure and interoperable binding that is suitable for non-duplex service contracts.
WSDualHttpBinding: A secure and interoperable binding that is suitable for duplex service contracts or communication through SOAP intermediaries.
WSFederationHttpBinding: A secure and interoperable binding that supports the WS-Federation protocol, enabling organizations that are in a federation to efficiently authenticate and authorize users.
NetTcpBinding:
A secure and optimized binding suitable for cross-machine communication between WCF applications
A secure and optimized binding suitable for cross-machine communication between WCF applications
NetNamedPipeBinding:
A secure, reliable, optimized binding that is suitable for on-machine communication between WCF applications.
A secure, reliable, optimized binding that is suitable for on-machine communication between WCF applications.
NetMsmqBinding:
A queued binding that is suitable for cross-machine communication between WCF applications.
A queued binding that is suitable for cross-machine communication between WCF applications.
NetPeerTcpBinding :
A binding that enables secure, multi-machine communication.
A binding that enables secure, multi-machine communication.
MsmqIntegrationBinding :
MsmqIntegrationBinding: A binding that is suitable for cross-machine communication between a WCF application and existing MSMQ applications.
It should be noted that WCF also allows us to define our own custom bindings.
CREATING A WCF SERVICE
In order to create a WCF service in Visual Studio, select WCF>WCF Service Library from the New Project dialog.
This will create the several files in a new project. Apart from the AppConfig file there are two more files – Service1.cs and IService1.cs . Service1.cs is an implementation of the IService1.cs interface.
Working with the Interface:
We need a service contract to create a new service. The service contract is the interface of the service. It consists of all the methods which are exposed along with input parameter(s) and return value.
Interface IService1.cs:
using System;
using System.Collections.Generic;
using System.Linq;
using System.Runtime.Serialization;
using System.ServiceModel;
using System.Text;
namespace WcfServiceLibrary1
{
[ServiceContract]
public interface IService1
{
[OperationContract]
int Addition(int x,int y);
[OperationContract]
Customer GetDataUsingDataContract(Customer cust);
}
[DataContract]
public class Customer
{
String name;
string contactNo;
[DataMember]
public string Name
{
get { return name; }
set { name = value; }
}
[DataMember]
public string ContactNo
{
get { return contactNo; }
set { contactNo = value; }
}
}
}
In the following class we can see that interface IService1is implemented.
No comments:
Post a Comment