WCF contract specify the service and its operations. WCF has five types of contracts: service contract, operation contract, data contract, message contract and fault contract.
Service Contract
A service contract defines the operations which are exposed by the service to the outside world. A service contract is the interface of the WCF service and it tells the outside world what the service can do. It may have service-level settings, such as the name of the service and namespace for the service.
- [ServiceContract]
- interface IMyContract
- {
- [OperationContract]
- string MyMethod();
- }
- class MyService : IMyContract
- {
- public string MyMethod()
- {
- return "Hello World";
- }
- }
Operation Contract
An operation contract is defined within a service contract. It defines the parameters and return type of an operation. An operation contract can also defines operation-level settings, like as the transaction flow of the op-eration, the directions of the operation (one-way, two-way, or both ways), and fault contract of the operation.
- [ServiceContract]
- interface IMyContract
- {
- [FaultContract(typeof(MyFaultContract))]
- [OperationContract]
- string MyMethod();
- }
Data Contract
A data contract defines the data type of the information that will be exchange be-tween the client and the service. A data contract can be used by an operation contract as a parameter or return type, or it can be used by a message contract to define elements.
- [DataContract]
- class Person
- {
- [DataMember]
- public string ID;
- [DataMember]
- public string Name;
- }
- [ServiceContract]
- interface IMyContract
- {
- [OperationContract]
- Person GetPerson(int ID);
- }
Message Contract
When an operation contract required to pass a message as a parameter or return value as a message, the type of this message will be defined as message contract. A message contract defines the elements of the message (like as Message Header, Message Body), as well as the message-related settings, such as the level of message security.
Message contracts give you complete control over the content of the SOAP header, as well as the structure of the SOAP body.
- [ServiceContract]
- public interface IRentalService
- {
- [OperationContract]
- double CalPrice(PriceCalculate request);
- }
- [MessageContract]
- public class PriceCalculate
- {
- [MessageHeader]
- public MyHeader SoapHeader { get; set; }
- [MessageBodyMember]
- public PriceCal PriceCalculation { get; set; }
- }
- [DataContract]
- public class MyHeader
- {
- [DataMember]
- public string UserID { get; set; }
- }
- [DataContract]
- public class PriceCal
- {
- [DataMember]
- public DateTime PickupDateTime { get; set; }
- [DataMember]
- public DateTime ReturnDateTime { get; set; }
- [DataMember]
- public string PickupLocation { get; set; }
- [DataMember]
- public string ReturnLocation { get; set; }
- }
Fault Contract
A fault contract defines errors raised by the service, and how the service handles and propagates errors to its clients. An operation contract can have zero or more fault contracts associated with it.
- [ServiceContract]
- interface IMyContract
- {
- [FaultContract(typeof(MyFaultContract1))]
- [FaultContract(typeof(MyFaultContract2))]
- [OperationContract]
- string MyMethod();
- [OperationContract]
- string MyShow();
- }
Comments
Post a Comment