Windows Communication Foundation (WCF) 中的传输安全机制取决于使用的绑定和后续传输。例如,当使用WSHttpBinding类时,传输为HTTP,保证传输安全的主要机制为HTTP上的安全套接字层(SSL)(通常称为 HTTPS)。本主题讨论WCF系统提供的绑定中使用的主要传输安全机制。
将SSL安全与 .NET Framework 3.5 和更高版本一起使用时,WCF 客户端将使用其证书存储区中的中间证书和 SSL 协商期间收到的中间证书,对服务的证书执行证书链验证。.NET Framework 3.0 仅使用本地证书存储区中安装的中间证书。
BasicHttpBinding
默认情况下,BasicHttpBinding 类不提供安全。此绑定旨在提供与不实现安全机制的 Web 服务提供程序的互操作性。但可以通过将 Mode 属性设置为 None 以外的值来启用安全。若要启用传输安全,请将该属性设置为 Transport。
BasicHttpBinding 类主要用于与现有的 Web 服务和由 Internet 信息服务 (IIS) 承载的许多服务进行互操作。因此,此绑定的传输安全旨在实现与 IIS 站点的无缝互操作。通过将安全模式设置为 Transport,然后设置客户端凭据类型可以实现这一目的。凭据类型值对应于 IIS 目录安全机制。下面的代码演示如何设置模式以及如何将凭据类型设置为 Windows。当客户端和服务器在同一个 Windows 域中时,您可以使用此配置。
或在配置中:
复制代码
<bindings> <basicHttpBinding> <binding name=”SecurityByTransport”> <security mode=”Transport”> <transport clientCredentialType=”Windows” /> </security> </binding> </basicHttpBinding></bindings> |
以下几节讨论其他客户端凭据类型。
基本
这对应于 IIS 中的基本身份验证方法。使用此模式时,必须为 IIS 服务器配置 Windows 用户帐户和适当的 NTFS 文件系统权限。有关 IIS 6.0 的更多信息,请参见启用基本身份验证和配置领域名(可能为英文网页)。有关 IIS 7.0 的更多信息,请参见 IIS 7.0 测试版本:配置基本身份验证(可能为英文网页)。
证书
IIS有一个要求客户端使用证书进行登录的选项。此功能还可以使 IIS 将客户端证书映射到 Windows 帐户。有关 IIS 6.0 的更多信息,请参见在 IIS 6.0 中启用客户端证书(可能为英文网页)。有关 IIS 7.0 的更多信息,请参见 IIS 7.0 测试版本:在 IIS 7.0 中配置服务器证书(可能为英文网页)。
摘要式
摘要式身份验证类似于基本身份验证,但其具有以哈希形式而不是明文形式发送凭据的优点。有关 IIS 6.0 的更多信息,请参见 IIS 6.0 中的摘要式身份验证(可能为英文网页)。有关 IIS 7.0 的更多信息,请参见 IIS 7.0 测试版本:配置摘要式身份验证(可能为英文网页)。
Windows
这对应于 IIS 中的集成 Windows 身份验证。设置为此值时,还需要服务器位于使用 Kerberos 协议作为其域控制器的 Windows 域中。如果服务器不在支持 Kerberos 的域中,或者如果 Kerberos 系统失败,您可以使用下一节中说明的 NT LAN Manager (NTLM) 值。有关 IIS 6.0 的更多信息,请参见 IIS 6.0 中的集成 Windows 身份验证(可能为英文网页)。有关 IIS 7.0 的更多信息,请参见 IIS 7.0 测试版本:在 IIS 7.0 中配置服务器证书(可能为英文网页)。
NTLM
这可使服务器在 Kerberos 协议失败时使用 NTLM 进行身份验证。有关 在 IIS 6.0 中配置 IIS 的更多信息,请参见强制 NTLM 身份验证(可能为英文网页)。对于 IIS 7.0,Windows 身份验证包括 NTLM 身份验证。有关更多信息,请参见 IIS 7.0 测试版本:在 IIS 7.0 中配置服务器证书(可能为英文网页)。
WSHttpBinding
WSHttpBinding 类专用于与实现 WS* 规范的服务进行互操作。此绑定的传输安全为 HTTP 上的安全套接字层 (SSL),即 HTTPS。若要创建使用 SSL 的 WCF 应用程序,请使用 IIS 承载该应用程序。或者,如果您要创建自承载的应用程序,请使用 HttpCfg.exe 工具将 X.509 证书绑定到计算机上的特定端口。端口号作为 WCF 应用程序的一部分以终结点地址的形式进行指定。使用传输模式时,终结点地址必须包括 HTTPS 协议,否则运行时将引发异常。有关更多信息,请参见 HTTP 传输安全。
对于客户端身份验证,请将 HttpTransportSecurity 类的 ClientCredentialType 属性设置为 HttpClientCredentialType 枚举值之一。枚举值与 BasicHttpBinding 的客户端凭据类型等同,并由 IIS 服务承载。
下面的示例演示与 Windows 的客户端凭据类型一起使用的绑定。
WSDualHttpBinding
此绑定只提供消息级别的安全,不提供传输级别的安全。
NetTcpBinding
NetTcpBinding 类使用 TCP 进行消息传输。通过实现 TCP 上的传输层安全性 (TLS) 为传输模式提供安全。由操作系统提供 TLS 实现。
也可以通过将 TcpTransportSecurity 类的 ClientCredentialType 属性设置为 TcpClientCredentialType 值之一来指定客户端的凭据类型,如果下面的代码所示。
客户端
在客户端,必须使用 X509CertificateInitiatorClientCredential 类的 SetCertificate 方法指定证书。
WCF传输安全 – Welcome – 思路注意: 如果您要使用 Windows 安全性,则不需要证书。
下面的代码使用唯一标识证书的证书指纹。有关 证书的更多信息,请参见使用证书。
或者,在客户端配置中的 behaviors 部分使用 clientCredentials element 指定证书。
复制代码
<behaviors> <behavior> <clientCredentials> <clientCertificate findValue= “101010101010101010101010101010000000000” storeLocation=”LocalMachine” storeName=”My” X509FindType=”FindByThumbPrint”/> </clientCertificate> </clientCredentials> </behavior></behaviors> |
NetNamedPipeBinding
NetNamedPipeBinding 类用于进行有效的计算机内通信;也就是说,虽然可以在同一网络上的两台计算机之间创建命名管道通道,但进程是在同一台计算机上运行的。此绑定只提供传输级别的安全。在创建使用此绑定的应用程序时,终结点地址必须包括“net.pipe”作为终结点地址的协议。
WSFederationHttpBinding
使用传输安全时,此绑定与已颁发的令牌 (TransportWithMessageCredential) 一起使用 HTTP 上的 SSL(称为 HTTPS)。有关 联合身份验证应用程序的更多信息,请参见联合令牌与颁发的令牌。
NetPeerTcpBinding
NetPeerTcpBinding类是旨在使用对等网络功能进行有效通信的一种安全传输。TCP 是协议,这与类和绑定的名称相一致。当安全模式设置为“传输”时,绑定将实现 TCP 上的 TLS。有关 对等功能的更多信息,请参见对等网络。
MsmqIntegrationBinding 和 NetMsmqBinding
有关消息队列(以前称为 MSMQ)的传输安全的完整讨论,请参见使用传输安全保护消息。
我们一直都在努力坚持原创.......请不要一声不吭,就悄悄拿走。
我原创,你原创,我们的内容世界才会更加精彩!
【所有原创内容版权均属TechTarget,欢迎大家转发分享。但未经授权,严禁任何媒体(平面媒体、网络媒体、自媒体等)以及微信公众号复制、转载、摘编或以其他方式进行使用。】
微信公众号
TechTarget
官方微博
TechTarget中国
相关推荐
-
微软IE9增加的7大安全机制
近日,微软发布了IE9 beta版。IE9是微软迄今为止支持标准最规范的IE浏览器。同时,IE9还改进了IE浏览器性能,增加了许多安全机制。
-
详解Win2000的12个安全防范对策
作为Win2000用户,我们该如何通过合理的方法来防范Win2000的安全呢?本文搜集和整理了防范Win2000安全的几则措施,现在把它们贡献出来,以供补充和完善……
-
国内企业安全的十个漏洞(下)
针对日益依赖互联网应用的现代企业来说,不断变化的安全威胁和不断变化的法规标准使得维护可信赖的网络环境成为一大难题。
-
国内企业安全的十个漏洞(上)
针对日益依赖互联网应用的现代企业来说,不断变化的安全威胁和不断变化的法规标准使得维护可信赖的网络环境成为一大难题。