SOA Patterns with BizTalk Server 2009
上QQ阅读APP看书,第一时间看更新

What is WCF?

In a nutshell, WCF is a framework for building and hosting services. Hosted by the Microsoft platform, WCF services make use of standard technologies to offer a wide range of cross-platform security, transaction, and communication capabilities.

Before WCF came along, .NET developers, who built distributed applications had to choose between communication schemes such as ASP.NET web services, .NET remoting, and MSMQ. This choice carried with it implications for how the component was designed, developed, deployed, and consumed. If you went with ASP.NET web services, you were committing to XML message formats and were handcuffed by limitations of the HTTP transport protocol. If you chose .NET remoting, you were able to process messages in an efficient fashion, but immediately limited yourself to .NET-only service clients. MSMQ is wonderful for disconnected applications, but in choosing it, you've eliminated any chance at having a synchronous, request-response conversation with a software client.

The goal of WCF is to unify these many technologies and provide a single transport-neutral development paradigm with common aspects for security, transactions, and exception handling. The service is implemented independent of the communication protocol strategy. This is a fairly revolutionary concept that introduces immense flexibility to service designers. Instead of building services with tightly coupled and rigid endpoints that do not welcome change, we can design flexible services that are capable of supporting a wide range of current and future consumers.

The service endpoint is king, and endpoints in WCF are defined using the easy-to-remember ABC acronym. The letter A stands for addressing, which refers to the actual URL of the service. The letter B stands for binding, which describes how we communicate with the service. Finally, the letter C stands for contract, which defines the operations and data elements that this service exposes. Let's look at each of these in detail.