LocalCertificateSelectionCallback LocalCertificateSelectionCallback LocalCertificateSelectionCallback LocalCertificateSelectionCallback Delegate

定義

認証に使用するローカルの SSL (Secure Sockets Layer) 証明書を選択します。 Selects the local Secure Sockets Layer (SSL) certificate used for authentication.

public delegate System::Security::Cryptography::X509Certificates::X509Certificate ^ LocalCertificateSelectionCallback(System::Object ^ sender, System::String ^ targetHost, X509CertificateCollection ^ localCertificates, X509Certificate ^ remoteCertificate, cli::array <System::String ^> ^ acceptableIssuers);
public delegate System.Security.Cryptography.X509Certificates.X509Certificate LocalCertificateSelectionCallback(object sender, string targetHost, X509CertificateCollection localCertificates, X509Certificate remoteCertificate, string[] acceptableIssuers);
type LocalCertificateSelectionCallback = delegate of obj * string * X509CertificateCollection * X509Certificate * string[] -> X509Certificate
Public Delegate Function LocalCertificateSelectionCallback(sender As Object, targetHost As String, localCertificates As X509CertificateCollection, remoteCertificate As X509Certificate, acceptableIssuers As String()) As X509Certificate 
パラメーター
sender
Object Object Object Object

この検証のステータス情報を格納するオブジェクト。 An object that contains state information for this validation.

targetHost
String String String String

クライアントが指定したホスト サーバー。 The host server specified by the client.

localCertificates
X509CertificateCollection X509CertificateCollection X509CertificateCollection X509CertificateCollection

ローカルの証明書を格納している X509CertificateCollection An X509CertificateCollection containing local certificates.

remoteCertificate
X509Certificate X509Certificate X509Certificate X509Certificate

リモート側の認証に使用される証明書。 The certificate used to authenticate the remote party.

acceptableIssuers
String[]

リモート側が受け入れることのできる証明書発行者の String 配列。 A String array of certificate issuers acceptable to the remote party.

戻り値
System.Security.Cryptography.X509Certificates.X509Certificate

SSL 接続の確立に使用する X509Certificate An X509Certificate used for establishing an SSL connection.

継承
LocalCertificateSelectionCallbackLocalCertificateSelectionCallbackLocalCertificateSelectionCallbackLocalCertificateSelectionCallback

次のコード例では、このデリゲート メソッドの実装を示します。The following code example demonstrates a method implementation for this delegate.

 static X509Certificate^ SelectLocalCertificate(
         Object^ sender, 
String^ targetHost, 
X509CertificateCollection^ localCertificates, 
X509Certificate^ remoteCertificate, 
array<String^>^ acceptableIssuers
 )
 {	
     Console::WriteLine("Client is selecting a local certificate.");
     if (acceptableIssuers != nullptr && 
             acceptableIssuers->Length > 0 &&
             localCertificates != nullptr &&
             localCertificates->Count > 0)
     {
         // Use the first certificate that is from an acceptable issuer.
         IEnumerator^ myEnum1 = localCertificates->GetEnumerator();
         while ( myEnum1->MoveNext() )
         {
	X509Certificate^ certificate = safe_cast<X509Certificate^>(myEnum1->Current);
	String^ issuer = certificate->Issuer;
	if ( Array::IndexOf( acceptableIssuers, issuer ) != -1 )
		return certificate;
         }
     }
     if (localCertificates != nullptr &&
             localCertificates->Count > 0)
return localCertificates[0];
             
     return nullptr;
  }

public static X509Certificate SelectLocalCertificate(
    object sender,
    string targetHost, 
    X509CertificateCollection localCertificates, 
    X509Certificate remoteCertificate, 
    string[] acceptableIssuers)
{	
    Console.WriteLine("Client is selecting a local certificate.");
    if (acceptableIssuers != null && 
        acceptableIssuers.Length > 0 &&
        localCertificates != null &&
        localCertificates.Count > 0)
    {
        // Use the first certificate that is from an acceptable issuer.
        foreach (X509Certificate certificate in localCertificates)
        {
            string issuer = certificate.Issuer;
            if (Array.IndexOf(acceptableIssuers, issuer) != -1)
                return certificate;
        }
    }
    if (localCertificates != null &&
        localCertificates.Count > 0)
        return localCertificates[0];
        
    return null;
}

次のコード例では、このデリゲートのインスタンスを作成するを示します。The following code example demonstrates creating an instance of this delegate.

// Server name must match the host name and the name on the host's certificate. 
serverName = args[ 1 ];

// Create a TCP/IP client socket.
TcpClient^ client = gcnew TcpClient( serverName,80 );
Console::WriteLine( L"Client connected." );

// Create an SSL stream that will close the client's stream.
SslStream^ sslStream = gcnew SslStream( 
    client->GetStream(),
    false,
    gcnew RemoteCertificateValidationCallback( ValidateServerCertificate ),
    gcnew LocalCertificateSelectionCallback( SelectLocalCertificate ) );

// Server name must match the host name and the name on the host's certificate. 
serverName = args[0];
// Create a TCP/IP client socket.
TcpClient client = new TcpClient(serverName,80);
Console.WriteLine("Client connected.");
// Create an SSL stream that will close the client's stream.
SslStream sslStream = new SslStream(
    client.GetStream(), 
    false, 
    new RemoteCertificateValidationCallback (ValidateServerCertificate), 
    new LocalCertificateSelectionCallback(SelectLocalCertificate)
    );

注釈

このデリゲートのインスタンスを構築するために使用、SslStreamクラス。This delegate is used to construct instances of the SslStream class. SslStreamクラスは、セキュリティで保護された情報がクライアントとサーバー間で交換するために使用します。The SslStream class is used to help secure information exchanged between a client and server. クライアントとサーバーは、このデリゲートを使用して、認証に使用する証明書を選択します。The client and server use this delegate to select a certificate to be used for authentication.

適用対象

こちらもご覧ください