如果用WCF编程使用的机器名不是localhost,网络允许在指定的端口上通信,这段代码就可以在网络上工作。另外,还可以把客户程序和主机应用程序分开得远一些,并通过Internet连接起来。
WCF编程定义服务的类在Service属性中声明,定义这个类的代码文件在CodeBehind属性中声明。这个指令是必须的,以获得Web服务器的主机功能,如前面几节所述。显然,没有存储在Web服务器上的WCF服务不需要这个文件。本章后面将学习自存储的WCF服务。
接着在IService1.cs文件中定义数据合同CompositeType。从代码中可以看出,数据合同只是一个类定义,在类定义中包含了DataContract属性,在类成员上包含了DataMember属性:
- [DataContract]
- public class CompositeType
- {
- bool boolValue = true;
- string stringValue = "Hello";
- [DataMember]
- public bool BoolValue
- {
- get { return boolValue; }
- set { boolValue = value; }
- }
- [DataMember]
- public string StringValue
- {
- get { return stringValue; }
- set { stringValue = value; }
- }
- }
这个数据合同通过元数据提供给客户应用程序(查看示例中的WSDL文件,就会看到这些元数据)。这允许客户应用程序定义一个类型,该类型可以序列化到窗体上,该窗体又可以由服务解序到CompositeType对象上。
客户程序不需要知道这个类型的定义,实际上,客户程序使用的类可以有不同的执行代码。定义数据合同的这种方式虽简单但非常强大,允许在WCF服务及其客户程序之间交换复杂的数据结构。
IService1.cs文件还包含服务合同,该服务合同定义为带有[ServiceContract]属性的接口。WCF编程这个接口也在服务的元数据中进行了完整的描述,并可以在客户应用程序中重建。
接口成员构建了服务的操作,每个操作都应用OperationContract属性创建一个操作合同。示例WCF编程包含两个操作,每个操作都使用了前面的数据合同:
- ServiceContract]
- public interface IService1
- {
- [OperationContract]
- string GetData(int value);
- [OperationContract]
- CompositeType GetDataUsingDataContract(CompositeType composite);
- }