Udostępnij za pośrednictwem


UserNamePasswordServiceCredential.CacheLogonTokens Właściwość

Definicja

Pobiera lub ustawia wartość wskazującą, czy tokeny logowania są buforowane.

public:
 property bool CacheLogonTokens { bool get(); void set(bool value); };
public bool CacheLogonTokens { get; set; }
member this.CacheLogonTokens : bool with get, set
Public Property CacheLogonTokens As Boolean

Wartość właściwości

Boolean

true jeśli tokeny logowania są buforowane; w przeciwnym razie , false. Wartość domyślna to false.

Przykłady

Poniższy przykład pobiera wartość tej właściwości.

// Create a service host.
Uri httpUri = new Uri("http://localhost/Calculator");
ServiceHost sh = new ServiceHost(typeof(Calculator), httpUri);

// Create a binding that uses a username/password credential.
WSHttpBinding b = new WSHttpBinding(SecurityMode.Message);
b.Security.Message.ClientCredentialType = MessageCredentialType.UserName;

// Add an endpoint.
sh.AddServiceEndpoint(typeof(ICalculator), b, "UserNamePasswordCalculator");

// Get a reference to the UserNamePasswordServiceCredential object.
UserNamePasswordServiceCredential unpCredential =
    sh.Credentials.UserNameAuthentication;
// Print out values.
Console.WriteLine("IncludeWindowsGroup: {0}",
    unpCredential.IncludeWindowsGroups);
Console.WriteLine("UserNamePasswordValidationMode: {0}",
    unpCredential.UserNamePasswordValidationMode);
Console.WriteLine("CachedLogonTokenLifetime.Minutes: {0}",
    unpCredential.CachedLogonTokenLifetime.Minutes );
Console.WriteLine("CacheLogonTokens: {0}",
    unpCredential.CacheLogonTokens );
Console.WriteLine("MaxCachedLogonTokens: {0}",
    unpCredential.MaxCachedLogonTokens );

Console.ReadLine();
' Create a service host.
Dim httpUri As New Uri("http://localhost/Calculator")
Dim sh As New ServiceHost(GetType(Calculator), httpUri)

' Create a binding that uses a username/password credential.
Dim b As New WSHttpBinding(SecurityMode.Message)
b.Security.Message.ClientCredentialType = MessageCredentialType.UserName

' Add an endpoint.
sh.AddServiceEndpoint(GetType(ICalculator), b, "UserNamePasswordCalculator")

' Get a reference to the UserNamePasswordServiceCredential object.
Dim unpCredential As UserNamePasswordServiceCredential = sh.Credentials.UserNameAuthentication
' Print out values.
Console.WriteLine("IncludeWindowsGroup: {0}", unpCredential.IncludeWindowsGroups)
Console.WriteLine("UserNamePasswordValidationMode: {0}", unpCredential.UserNamePasswordValidationMode)
Console.WriteLine("CachedLogonTokenLifetime.Minutes: {0}", unpCredential.CachedLogonTokenLifetime.Minutes)
Console.WriteLine("CacheLogonTokens: {0}", unpCredential.CacheLogonTokens)
Console.WriteLine("MaxCachedLogonTokens: {0}", unpCredential.MaxCachedLogonTokens)

Console.ReadLine()

Uwagi

Domyślnie zabezpieczenia programu WCF pytają podsystem zabezpieczeń Windows o utworzenie tokenu logowania dla każdego przychodzącego tokenu zabezpieczającego nazwy użytkownika/hasła, jeśli nazwa użytkownika jest mapowana na konto Windows. To zachowanie można zmienić, ustawiając UserNamePasswordValidationMode właściwość .

W Windows przypadku trybu usługa używa funkcji Win32 LogonUser do uwierzytelniania nazwy użytkownika/hasła. CacheLogonTokens Jeśli parametr ma wartość true, wynikowy token Windows jest buforowany i ponownie używany dla tej samej pary nazw użytkowników/haseł. Pamięć podręczna jest prawidłowa dla .CachedLogonTokenLifetime Maksymalna liczba pamięci podręcznych jest ograniczona do MaxCachedLogonTokens.

Dotyczy