WCF入门教程(四)通过Host代码方式来承载服务

时间:2022-01-03 12:50:12

WCF入门教程(四)通过Host代码方式来承载服务

之前已经讲过WCF对外发布服务的具体方式。

WCF入门教程(一)简介

Host承载,可以是web,也可以是控制台程序等等。比WebService有更大的使用空间。具体承载的简单框图如下:

WCF入门教程(四)通过Host代码方式来承载服务

通过服务终结点,然后通过Host承载这些终结点,这样客户端就可以访问这些服务了。

一个服务可以添加多个终结点,终结点中定义了Address,Binding和Contract。

而且还可以针对终结点定义一定的行为。

下面给出简单实例,通过ServiceHost来承载相关服务。

            #region 采用代码方式实现对契约的绑定
Uri baseAddress = new Uri("http://127.0.0.1:9999/");
using (ServiceHost host = new ServiceHost(typeof(CalculatorService), baseAddress))
{
Binding wsBinding = new WSHttpBinding();
NetTcpBinding tcpBinding = new NetTcpBinding();
//提供安全传输
tcpBinding.Security.Mode = SecurityMode.Transport;
//需要提供证书
tcpBinding.Security.Transport.ClientCredentialType = TcpClientCredentialType.Certificate; //添加多个服务终结点
//使用指定的协定、绑定和终结点地址将服务终结点添加到承载服务中
ServiceEndpoint svEndpiont = host.AddServiceEndpoint(typeof(ICalculator), wsBinding, "CalculatorService");
//netTcp协议终结点
host.AddServiceEndpoint(typeof(ICalculator), tcpBinding, "net.tcp://127.0.0.1:8888/CalculatorServiceTcp"); #region 添加行为
//元数据发布行为
ServiceMetadataBehavior behavior = new ServiceMetadataBehavior();
//支持get请求
behavior.HttpGetEnabled = true;
behavior.HttpGetUrl = new Uri("http://127.0.0.1:9999/CalculatorService/metadata");
//设置到Host中
host.Description.Behaviors.Add(behavior);
#endregion host.Opened += delegate
{
Console.WriteLine("CalculaorService已经启动,按任意键终止服务!");
}; //服务启动
host.Open();
Console.Read();
}
#endregion

如果已经很了解这些类型的使用了,后面的内容可以直接略过。

ServiceHost

提供服务的主机。就是服务的承载者。

主要属性:

名称

说明

Authentication

获取服务身份验证行为。

Authorization

获取所承载服务的授权行为。

BaseAddresses

获取所承载服务使用的基址。

ChannelDispatchers

获取服务主机所使用的通道调度程序的集合。

CloseTimeout

获取或设置允许服务主机关闭的时间间隔。

OpenTimeout

获取或设置允许服务主机打开的时间间隔。

SingletonInstance

获取承载服务的单一实例。

State

获取指示通信对象当前状态的值。

主要方法:

其方法很多,Host开启、关闭、终止等,还支持异步操作,以及一些动作前后事件。在这里只列举了最基本几个方法。

名称

说明

AddServiceEndpoint(Type, Binding, String)

使用指定的协定、绑定和终结点地址将服务终结点添加到承载服务中。

Close()

使通信对象从其当前状态转换到关闭状态。 (继承自 CommunicationObject。)

OnOpened

获取所承载服务的服务凭据、服务身份验证和授权行为。 (继承自ServiceHostBase。)

Open()

使通信对象从已创建状态转换到已打开状态。 (继承自 CommunicationObject。)

ServiceEndpoint

表示允许服务的客户端查找并与服务通信的服务的终结点。

该服务终结点包含客户端在此终结点进行查找和与服务交互所需的地址、绑定、协定和行为信息。

属性:

名称

说明

Address

获取或设置服务终结点的终结点地址。

Behaviors

获取服务终结点的行为。

Binding

获取或设置服务终结点的绑定。

Contract

获取服务终结点的协定。

IsSystemEndpoint

获取或设置是否由系统生成服务终结点而不由用户定义服务终结点。

ListenUri

获取或设置服务终结点侦听的 URI。

ListenUriMode

获取或设置传输处理提供给服务的供其侦听的 URI 的方式。

Name

获取或设置服务终结点的名称。

Binding

包含绑定元素,这些元素指定客户端和服务之间的通信所用的协议、传输和消息编码器。

这李只给出几种常见的绑定类型,不深入展开

具体绑定规则根据具体需求而定。

Binding名称

Configuration Element

描述

BasicHttpBinding

basicHttpBinding

一个指定用符合基本网络服务规范通讯的binding,它用http进行传输,数据格式为text/xml

WSHttpBinding

wsHttpBinding

一个安全的通用的binding,但它不能在deplex中使用

WSDualHttpBinding

wsDualHttpBinding

一个安全的通用的binding,但能在deplex中使用

WSFederationHttpBinding

wsFederationHttpBinding

一个安全的通用的支持WSF的binding,能对用户进行验证和授权

NetTcpBinding

netTcpBinding

在wcf应用程序中最适合跨机器进行安全通讯的binding

NetNamedPipeBinding

netNamedPipeBinding

在wcf应用程序中最适合本机进行安全通讯的binding

NetMsmqBinding

netMsmqBinding

在wcf应用程序中最适合跨机器进行安全通讯的binding,并且支持排队

NetPeerTcpBinding

netPeerTcpBinding

一个支持安全的,多机交互的binding

MsmqIntegrationBinding

msmqIntegrationBinding

一个用于wcf与现有msmq程序进行安全通讯的binding

ServiceDescription

表示一个完整的服务的内存中说明,包括服务的所有终结点及其各自地址、绑定、协定和行为的规范。

名称

说明

Behaviors

获取与该服务关联的行为。

ConfigurationName

获取或设置 <service> 配置元素的名称。

Endpoints

从服务说明获取终结点的集合。

Name

获取或设置服务的名称。

Namespace

获取或设置服务的命名空间。

ServiceType

获取服务的类型。

ServiceMetadataBehavior

控制服务元数据和相关信息的发布。

属性

说明

ExternalMetadataLocation

获取或设置作为服务元数据的位置的值。

HttpGetBinding

获取或设置当传输为 HTTP 时用于配置元数据检索的绑定。

HttpGetEnabled

获取或设置一个值,该值指示是否发布服务元数据以便使用 HTTP/GET 请求进行检索。

HttpGetUrl

获取或设置进行 HTTP/GET 请求的元数据发布的位置。

HttpsGetBinding

获取或设置当传输为 HTTPS 时用于配置元数据检索的绑定。

HttpsGetEnabled

获取或设置一个值,该值指示是否发布服务元数据以便使用 HTTPS/GET 请求进行检索。

HttpsGetUrl

获取或设置进行 HTTPS/GET 请求的元数据发布的位置。

MetadataExporter

获取或设置用于发布服务元数据的内部 MetadataExporter 对象。