HttpListener.AuthenticationSchemeSelectorDelegate Propriedade

Definição

Recebe ou define o delegado chamado para determinar o protocolo usado para autenticar clientes.

public:
 property System::Net::AuthenticationSchemeSelector ^ AuthenticationSchemeSelectorDelegate { System::Net::AuthenticationSchemeSelector ^ get(); void set(System::Net::AuthenticationSchemeSelector ^ value); };
public System.Net.AuthenticationSchemeSelector AuthenticationSchemeSelectorDelegate { get; set; }
member this.AuthenticationSchemeSelectorDelegate : System.Net.AuthenticationSchemeSelector with get, set
Public Property AuthenticationSchemeSelectorDelegate As AuthenticationSchemeSelector

Valor de Propriedade

Um AuthenticationSchemeSelector delegado que invoca o método usado para selecionar um protocolo de autenticação. O valor predefinido é null.

Exceções

Este objeto foi encerrado.

Exemplos

O seguinte exemplo de código define o valor desta propriedade.

// Set up a listener.
HttpListener listener = new HttpListener();
HttpListenerPrefixCollection prefixes = listener.Prefixes;
prefixes.Add(@"http://localhost:8080/");
prefixes.Add(@"http://contoso.com:8080/");

// Specify the authentication delegate.
listener.AuthenticationSchemeSelectorDelegate =
    new AuthenticationSchemeSelector (AuthenticationSchemeForClient);

// Start listening for requests and process them
// synchronously.
listener.Start();
' Set up a listener.
Dim listener As New HttpListener()
Dim prefixes As HttpListenerPrefixCollection = listener.Prefixes
prefixes.Add("http://localhost:8080/")
prefixes.Add("http://contoso.com:8080/")

' Specify the authentication delegate.
listener.AuthenticationSchemeSelectorDelegate = New AuthenticationSchemeSelector(AddressOf AuthenticationSchemeForClient)

' Start listening for requests and process them 
' synchronously.
listener.Start()

O seguinte exemplo de código fornece uma implementação de um método invocado por um AuthenticationSchemeSelector delegado.

static AuthenticationSchemes AuthenticationSchemeForClient(HttpListenerRequest request)
{
    Console.WriteLine("Client authentication protocol selection in progress...");
    // Do not authenticate local machine requests.
    if (request.RemoteEndPoint.Address.Equals (IPAddress.Loopback))
    {
        return AuthenticationSchemes.None;
    }
    else
    {
        return AuthenticationSchemes.IntegratedWindowsAuthentication;
    }
}
Private Shared Function AuthenticationSchemeForClient(ByVal request As HttpListenerRequest) As AuthenticationSchemes
    Console.WriteLine("Client authentication protocol selection in progress...")
    ' Do not authenticate local machine requests.
    If request.RemoteEndPoint.Address.Equals(IPAddress.Loopback) Then
        Return AuthenticationSchemes.None
    Else
        Return AuthenticationSchemes.IntegratedWindowsAuthentication
    End If
End Function

Observações

Note

Se quiser que o mesmo protocolo de autenticação seja usado para todos os pedidos tratados por uma instância particular de HttpListener, não precisa de definir esta propriedade. Para especificar um protocolo a ser usado para todos os pedidos do cliente, use a AuthenticationSchemes propriedade.

Se o cliente não tiver especificado informação de autenticação nos seus cabeçalhos, chama HttpListener o delegado especificado para cada pedido recebido não autenticado para determinar qual, se algum, protocolo usar para autenticar o cliente. Os GetContext métodos e EndGetContext retornam um pedido recebido apenas se o HttpListener tiver autenticado com sucesso. Se um pedido não puder ser autenticado, envia HttpListener automaticamente uma resposta 401. Pode obter a identidade de um cliente autenticado com sucesso usando a HttpRequest.LogonUserIdentity propriedade.

A capacidade de delegar a escolha do protocolo de autenticação a um método específico da aplicação é útil se quiser que uma instância de HttpListener utilize protocolos de autenticação diferentes, dependendo das características dos pedidos que recebe (por exemplo, o pedido Url ou UserHostAddress propriedade).

Note

Para definir esta propriedade para permitir Digest, NTLM ou Negotiate, é necessário o SecurityPermission, ControlPrincipal.

Aplica-se a