AuthenticationSchemes Перечисление
Определение
Важно!
Некоторые сведения относятся к предварительной версии продукта, в которую до выпуска могут быть внесены существенные изменения. Майкрософт не предоставляет никаких гарантий, явных или подразумеваемых, относительно приведенных здесь сведений.
Задает протоколы для проверки подлинности.
Это перечисление поддерживает побитовую комбинацию значений его членов.
public enum class AuthenticationSchemes
[System.Flags]
public enum AuthenticationSchemes
[<System.Flags>]
type AuthenticationSchemes =
Public Enum AuthenticationSchemes
- Наследование
- Атрибуты
Поля
| Имя | Значение | Описание |
|---|---|---|
| None | 0 | Проверка подлинности не разрешена. Клиент, запрашивающий HttpListener объект с этим набором флагов, всегда получает состояние "Запрещено" 403. Используйте этот флаг, когда ресурс никогда не должен обслуживаться клиенту. |
| Digest | 1 | Указывает сводную аутентификацию. |
| Negotiate | 2 | Согласовывается с клиентом, чтобы определить схему проверки подлинности. Если клиент и сервер поддерживают Kerberos, он используется; в противном случае используется NTLM. |
| Ntlm | 4 | Указывает проверку подлинности NTLM. |
| IntegratedWindowsAuthentication | 6 | Указывает аутентификацию Windows. |
| Basic | 8 | Указывает базовую проверку подлинности. |
| Anonymous | 32768 | Указывает анонимную проверку подлинности. |
Примеры
В следующем примере кода показано использование значения перечисления "Согласование", чтобы указать, что клиенты проходят проверку подлинности с помощью протокола безопасности "Согласование".
Console.WriteLine("Listening for {0} prefixes...", listener.Prefixes.Count);
HttpListenerContext context = listener.GetContext();
HttpListenerRequest request = context.Request;
Console.WriteLine("Received a request.");
// This server requires a valid client certificate
// for requests that are not sent from the local computer.
// Did the client omit the certificate or send an invalid certificate?
if (request.IsAuthenticated &&
request.GetClientCertificate() == null ||
request.ClientCertificateError != 0)
{
// Send a 403 response.
HttpListenerResponse badCertificateResponse = context.Response ;
SendBadCertificateResponse(badCertificateResponse);
Console.WriteLine("Client has invalid certificate.");
continue;
}
Console.WriteLine("Listening for {0} prefixes...", listener.Prefixes.Count)
Dim context As HttpListenerContext = listener.GetContext()
Dim request As HttpListenerRequest = context.Request
Console.WriteLine("Received a request.")
' This server requires a valid client certificate
' for requests that are not sent from the local computer.
' Did the client omit the certificate or send an invalid certificate?
If request.IsAuthenticated AndAlso request.GetClientCertificate() Is Nothing OrElse request.ClientCertificateError <> 0 Then
' Send a 403 response.
Dim badCertificateResponse As HttpListenerResponse = context.Response
SendBadCertificateResponse(badCertificateResponse)
Console.WriteLine("Client has invalid certificate.")
Continue Do
End If
Комментарии
Это перечисление используется для указания метода, используемого для проверки подлинности клиентских запросов, обрабатываемых HttpListener объектами.
Important
Для обычной проверки подлинности требуется обмен паролем и поэтому следует избегать, кроме случаев безопасных зашифрованных подключений.
Дополнительные сведения об базовой и дайджест-проверке подлинности см. в разделе RFC2617 — проверка подлинности HTTP: обычная и дайджест-проверка подлинности. Этот документ доступен по адресу https://www.rfc-editor.org.