绑定与安全

包含在Windows Communication Foundation (WCF) 中的系统提供的绑定提供了一种编写 WCF 应用程序的快捷方法。 但有一个例外,就是所有绑定都启用了默认的安全方案。 本主题将帮助你根据安全需要来选择正确的绑定。

有关 WCF 安全性的概述,请参阅安全性概述。 有关使用绑定对 WCF 编程的详细信息,请参阅编程 WCF 安全性

如果已经选择了绑定,有关与安全相关的运行时行为的更多信息,请参阅安全行为

部分安全性功能无法用系统提供的绑定进行编程。 有关使用自定义绑定的更多控件,请参阅自定义绑定的安全功能

绑定的安全功能

WCF 包含许多由系统提供的绑定,这些绑定可以满足大多数需求。 如果某个特定绑定不能满足要求,您还可以创建自定义绑定。 有关系统提供的绑定的列表,请参见系统提供的绑定。 有关自定义绑定的详细信息,请参阅自定义绑定

WCF 中的每个绑定都具有两种形式:一种是 API,一种是在配置文件中使用的 XML 元素。 例如,WSHttpBinding (API) 在 <wsHttpBinding> 中具有对应项。

下一节列出了每个绑定的两种形式,并概括了安全功能。

BasicHttp

在代码中,请使用 BasicHttpBinding 类;在配置中,请使用 <basicHttpBinding>

此绑定的目的是与如下一系列现有技术一起使用:

  • ASP.NET Web 服务 (ASMX) 版本 1。

  • Web Service Enhancements (WSE) 应用程序。

  • Web 服务互操作性 (WS-I) 规范中定义的基本配置文件 (https://go.microsoft.com/fwlink/?LinkId=38955)。

  • WS-I 中定义的基本安全配置文件。

默认情况下,此绑定是不安全的。 它的目的是与 ASMX 服务进行互操作。 启用安全性后,此绑定可以与 Internet 信息服务 (IIS) 安全机制(例如基本身份验证、摘要和 Windows 集成安全性)进行无缝的互操作。 有关详细信息,请参阅传输安全概述。 此绑定支持以下功能:

  • HTTPS 传输安全。

  • HTTP 基本身份验证。

  • WS-Security。

有关详细信息,请参阅BasicHttpSecurity, BasicHttpMessageSecurity, BasicHttpMessageCredentialTypeBasicHttpSecurityMode.

WSHttpBinding

在代码中,请使用 WSHttpBinding 类;在配置中,请使用 <wsHttpBinding>

默认情况下,此绑定实现 WS-Security 规范,并提供与实现 WS-* 规范的服务的互操作性。 它支持以下功能:

  • HTTPS 传输安全。

  • WS-Security。

  • 使用 SOAP 消息凭据安全对调用方进行身份验证的 HTTPS 传输保护。

有关更多信息,请参阅 WSHttpSecurityMessageSecurityOverHttpMessageCredentialTypeSecurityModeHttpTransportSecurityHttpClientCredentialTypeHttpProxyCredentialType

WSDualHttpBinding

在代码中,请使用 WSDualHttpBinding 类;在配置中,请使用 <wsDualHttpBinding>

此绑定的目的是启用双工服务应用程序。 此绑定实现了 WS-Security 规范,以便获得基于消息的传送安全。 传输安全不可用。 默认情况下,它提供下列功能:

  • 实现 WS-Reliable Messaging 以保证可靠性。

  • 实现 WS-Security 以保证传送安全和身份验证。

  • 使用 HTTP 进行消息传递。

  • 使用文本/XML 消息编码。

使用 WS-Security(消息层安全性),可通过此绑定配置下列参数:

  • 用来确定加密算法的安全算法组。

  • 下列功能的绑定选项:

    • 提供可在客户端带外使用的服务凭据。

    • 提供从服务协商的服务凭据作为通道设置的一部分。

有关详细信息,请参阅 WSDualHttpSecurityWSDualHttpSecurityMode

NetTcpBinding

在代码中,请使用 NetTcpBinding 类;在配置中,请使用 <netTcpBinding>

此绑定针对计算机之间的通信进行了优化。 默认情况下,它具有以下特征:

  • 实现传输层安全性。

  • 利用 Windows 安全性来实现传送安全性和身份验证。

  • 使用 TCP 进行传输。

  • 实现二进制消息编码。

  • 实现 WS-Reliable Messaging。

此绑定具有下列选项:

  • 消息层安全性(使用 WS-Security)。

  • 使用消息凭据实现传输安全性:保密性和完整性由 Transport Layer Security (TLS) over TCP 提供,授权凭据由 WS-Security 提供。

有关更多信息,请参阅 NetTcpSecurityTcpTransportSecurityTcpClientCredentialTypeMessageSecurityOverTcpMessageCredentialType

NetNamedPipeBinding

在代码中,请使用 NetNamedPipeBinding 类;在配置中,请使用 <netNamedPipeBinding>

此绑定针对进程之间的通信(通常在同一台计算机上)进行了优化。 默认情况下,此绑定具有以下特征:

  • 使用传输安全性来实现消息传输和身份验证。

  • 使用命名管道进行消息传递。

  • 实现二进制消息编码。

  • 加密和消息签名。

此绑定具有下列选项:

  • 使用 Windows 安全性进行身份验证。

有关详细信息,请参阅NetNamedPipeSecurityNetNamedPipeSecurityModeNamedPipeTransportSecurity

MsmqIntegrationBinding

在代码中,请使用 MsmqIntegrationBinding 类;在配置中,请使用 <msmqIntegrationBinding>

此绑定最适合于创建与非 WCF Microsoft 消息队列 (MSMQ) 终结点进行互操作的 WCF 客户端和服务。

默认情况下,此绑定使用传输安全性并提供下列安全特征:

  • 可以禁用安全性 (None)。

  • MSMQ 传输安全性 (Transport)。

有关详细信息,请参阅 NetMsmqSecurityNetMsmqSecurityMode

NetMsmqBinding

在代码中,请使用 NetMsmqBinding 类;在配置中,请使用 <netMsmqBinding>

此绑定适合在创建需要 MSMQ 排队消息支持的 WCF 服务时使用。

默认情况下,此绑定使用传输安全性并提供下列安全特征:

  • 可以禁用安全性 (None)。

  • MSMQ 传输安全性 (Transport)。

  • 基于 SOAP 的消息安全性 (Message)。

  • 同时启用传输安全性和消息安全性 (Both)。

  • 支持的客户端凭据类型:None、Windows、UserName、Certificate、IssuedToken。

仅当安全模式设置为 CertificateBoth 时,才支持 Message 凭据。

有关详细信息,请参阅 MessageSecurityOverMsmqMsmqTransportSecurity

WSFederationHttpBinding

在代码中,请使用 WSFederationHttpBinding 类;在配置中,请使用 <wsFederationHttpBinding>

默认情况下,此绑定使用 WS-Security(消息层安全性)。

有关详细信息,请参阅联合身份验证WSFederationHttpSecurityWSFederationHttpSecurityMode

自定义绑定

如果系统提供的绑定都不能满足您的需求,则可以使用自定义安全绑定元素来创建自定义绑定。 有关详细信息,请参阅使用自定义绑定的安全功能

绑定选择

下表概括了安全模式设置中提供的功能,也就是说,它列出了当安全模式设置为 TransportMessageTransportWithMessageCredential 时可以使用的功能。 使用此表可帮助您找到应用程序所需的安全功能。

设置 功能
Transport 服务器身份验证

客户端身份验证

点对点安全性

互操作性

硬件加速

高吞吐量

安全防火墙

高延迟应用程序

跨越多个跃点重新加密
消息 服务器身份验证

客户端身份验证

端到端安全性

互操作性

丰富的声明

联合

多重身份验证

自定义令牌

公证人/时间戳服务

高延迟应用程序

消息签名的持久性
TransportWithMessageCredential 服务器身份验证

客户端身份验证

点对点安全性

互操作性

硬件加速

高吞吐量

丰富的客户端声明

联合

多重身份验证

自定义令牌

安全防火墙

高延迟应用程序

跨越多个跃点重新加密

下表列出了支持各种模式设置的绑定。 请从该表中选择用来创建服务终结点的绑定。

绑定 是否支持 Transport 模式 是否支持 Message 模式 是否支持 TransportWithMessageCredential
BasicHttpBinding
WSHttpBinding
WSDualHttpBinding No No
NetTcpBinding
NetNamedPipeBinding No
NetMsmqBinding No
MsmqIntegrationBinding No
wsFederationHttpBinding No

绑定中的传输凭据

下表列出了在传输安全模式下使用 BasicHttpBindingWSHttpBinding 时可用的客户端凭据类型。

类型 描述
指定客户端不需要提供任何凭据。 这相当于匿名客户端。
基本 基本身份验证 有关详细信息,请在 https://go.microsoft.com/fwlink/?LinkId=84023 参阅 RFC 2617 - HTTP 身份验证:基本和摘要式身份验证。
摘要 摘要式身份验证。 有关详细信息,请在 https://go.microsoft.com/fwlink/?LinkId=84023 参阅 RFC 2617 - HTTP 身份验证:基本和摘要式身份验证。
NTLM NT LAN Manager (NTLM) 身份验证。
Windows Windows 身份验证。
证书 使用证书执行的身份验证。
IssuedToken 允许服务要求使用由安全令牌服务或 CardSpace 颁发的令牌对客户端进行身份验证。 有关详细信息,请参阅联合身份验证和颁发的标记

绑定中的消息客户端凭据

下表列出在 Message 安全模式下使用绑定时可用的客户端凭据类型。

类型 描述
允许服务与匿名客户端交互。
Windows 允许在 Windows 凭据的已通过身份验证的上下文中执行 SOAP 消息交换。
UserName 允许服务要求使用用户名凭据对客户端进行身份验证。 请注意,当安全模式设置为 TransportWithMessageCredential 时,WCF 不支持发送密码摘要,也不支持使用密码派生密钥并将这样的密钥用于 Message 模式安全。 因此,WCF 强制要求在使用用户名凭据时确保传输的安全性。
证书 允许服务要求使用证书对客户端进行身份验证。
IssuedToken 允许服务使用安全令牌服务来提供自定义令牌。

请参阅