共用方式為


作法:建立支援的認證

您可能具有需要多個認證的自訂安全性配置。 例如,服務對用戶端的要求可能不只是提供使用者名稱和密碼,可能也要提供可證明用戶端已超過 18 歲的認證。 第二個認證是支援認證。 此主題說明如何在 Windows Communication Foundation (WCF) 用戶端中實作此類認證。

注意

支援認證的規格為 WS-SecurityPolicy 規格的一部分。 如需詳細資訊,請參閱 Web 服務安全性規格

支援權杖

簡單來說,當您使用訊息安全性時,一律會使用主要認證保護訊息 (例如,X.509 憑證或 Kerberos 票證)。

如規格所定義,安全性繫結會使用權杖來保護訊息交換。 權杖是一種安全性認證的表示法。

安全性繫結會使用安全性繫結原則中識別的主要權杖來建立簽章。 此簽章也稱為訊息簽章

您也可以指定其他權杖,以擴大與訊息簽章相關聯的權杖所提供的宣告。

簽署 (Endorsing)、簽署 (Signing) 和加密

支援認證會產生在訊息內傳輸的支援權杖。 WS-SecurityPolicy 規格定義了四種可將支援權杖附加至訊息的方法,如下表所述。

目的 描述
Signed 支援權杖包含在安全性標頭中,而且是由訊息簽章進行簽署。
簽署 簽署權杖會簽署訊息簽章。
已簽署 (Signed) 和簽署 (Endorsing) 已簽署的簽署權杖會簽署從訊息簽章產生的整個 ds:Signature 項目,而這些權杖本身就是由該訊息簽章所簽署;也就是說,這兩個權杖 (用於訊息簽章的權杖和已簽署的簽署權杖) 會彼此進行簽署。
已簽署和加密 已簽署的加密支援權杖是出現在 wsse:SecurityHeader 時,也會進行加密的已簽署支援權杖。

程式設計的支援認證

若要建立可使用支援權杖的服務,您必須建立 <customBinding> (如需詳細資訊,請參閱作法:使用 SecurityBindingElement 建立自訂繫結)。

建立自訂繫結的第一個步驟為建立安全性繫結項目,可以是下列三種類型的其中之一:

繼承自 SecurityBindingElement 的所有類別,可包含四個相關的屬性:

範圍

支援認證中有兩個範圍:

  • 端點支援權杖支援端點的所有作業。 這也就是支援權杖所表示的認證,可以在每次叫用端點作業時使用此認證。

  • 作業支援權杖僅支援特定的端點作業。

如屬性名稱所指出,支援認證可以為必要項目或選用項目。 也就是說,如果在出現支援認證時使用該認證 (雖然不需要該認證),在沒有出現該認證時驗證也不會失敗。

程序

建立包含支援認證的自訂繫結

  1. 建立安全性繫結項目。 底下的範例會使用 SymmetricSecurityBindingElement 驗證模式建立 UserNameForCertificate。 使用 CreateUserNameForCertificateBindingElement 方法。

  2. 將支援參數新增至適當屬性 (EndorsingSignedSignedEncryptedSignedEndorsed) 所傳回的類型集合。 System.ServiceModel.Security.Tokens 命名空間中的類型包含常用類型,例如 X509SecurityTokenParameters

範例

描述

下列範例會建立 SymmetricSecurityBindingElement 的執行個體,並將 KerberosSecurityTokenParameters 類別的執行個體新增至所傳回的簽署屬性集合。

程式碼

public static Binding CreateMultiFactorAuthenticationBinding()
{
    HttpTransportBindingElement httpTransport = new HttpTransportBindingElement();

    // The message security binding element will be configured to require 2 tokens:
    // 1) A user name/password encrypted with the service token.
    // 2) A client certificate used to sign the message.

    // Instantiate a binding element that will require the user name/password token
    // in the message (encrypted with the server certificate).
    SymmetricSecurityBindingElement messageSecurity = SecurityBindingElement.CreateUserNameForCertificateBindingElement();

    // Create supporting token parameters for the client X.509 certificate.
    X509SecurityTokenParameters clientX509SupportingTokenParameters = new X509SecurityTokenParameters();
    // Specify that the supporting token is passed in the message send by the client to the service.
    clientX509SupportingTokenParameters.InclusionMode = SecurityTokenInclusionMode.AlwaysToRecipient;
    // Turn off derived keys.
    clientX509SupportingTokenParameters.RequireDerivedKeys = false;
    // Augment the binding element to require the client's X.509 certificate as an
    // endorsing token in the message.
    messageSecurity.EndpointSupportingTokenParameters.Endorsing.Add(clientX509SupportingTokenParameters);

    // Create a CustomBinding based on the constructed security binding element.
    return new CustomBinding(messageSecurity, httpTransport);
}

另請參閱