AuditLogLocation AuditLogLocation AuditLogLocation AuditLogLocation Enum

Definizione

Specifica il percorso in cui vengono scritti i registri eventi di sicurezza.Specifies the location where security-related event logs are written.

public enum class AuditLogLocation
public enum AuditLogLocation
type AuditLogLocation = 
Public Enum AuditLogLocation
Ereditarietà
AuditLogLocationAuditLogLocationAuditLogLocationAuditLogLocation

Campi

Application Application Application Application 1

Specifica come registro eventi il Registro applicazioni.Specifies the Application log in the event log.

Default Default Default Default 0

Specifica la posizione predefinita, determinata dal sistema operativo.Specifies the default location, which is determined by the operating system. Se il sistema supporta la scrittura nel registro sicurezza (come accade ad esempio nelle piattaforme Windows VistaWindows Vista e Windows Server 2003Windows Server 2003 e versioni successive), il percorso del registro predefinito è il registro sicurezza.If writing to the Security log is supported (such as on Windows VistaWindows Vista and Windows Server 2003Windows Server 2003 and later platforms), the default log location is the Security log. In caso contrario (come accade ad esempio in Windows XP SP2Windows XP SP2), il percorso del registro predefinito è il registro applicazioni.Otherwise (such as in Windows XP SP2Windows XP SP2), the default log location is the Application log.

Security Security Security Security 2

Specifica come registro eventi il Registro sicurezza.Specifies the Security log in the event log. Per poter scrivere nel registro sicurezza, il thread chiamante deve disporre del privilegio SeAuditPrivilege.The calling thread must have SeAuditPrivilege to be able to write to the Security log.

Esempi

Nell'esempio seguente la ServiceSecurityAuditBehavior.AuditLogLocation proprietà viene impostata su uno AuditLogLocation dei valori di:The following example sets the ServiceSecurityAuditBehavior.AuditLogLocation property to one of the AuditLogLocation values:

public static void Main()
{
    // Get base address from appsettings in configuration.
    Uri baseAddress = new Uri(ConfigurationManager.
        AppSettings["baseAddress"]);

    // Create a ServiceHost for the CalculatorService type 
    // and provide the base address.
    using (ServiceHost serviceHost = new 
        ServiceHost(typeof(CalculatorService), baseAddress))
    {
        // Create a new auditing behavior and set the log location.
        ServiceSecurityAuditBehavior newAudit = 
            new ServiceSecurityAuditBehavior();
        newAudit.AuditLogLocation = 
            AuditLogLocation.Application;
        newAudit.MessageAuthenticationAuditLevel = 
            AuditLevel.SuccessOrFailure;
        newAudit.ServiceAuthorizationAuditLevel = 
            AuditLevel.SuccessOrFailure;
        newAudit.SuppressAuditFailure = false;
        // Remove the old behavior and add the new.
        serviceHost.Description.
            Behaviors.Remove<ServiceSecurityAuditBehavior>();
        serviceHost.Description.Behaviors.Add(newAudit);
        // Open the ServiceHostBase to create listeners 
        // and start listening for messages.
        serviceHost.Open();

        // The service can now be accessed.
        Console.WriteLine("The service is ready.");
        Console.WriteLine("Press <ENTER> to terminate service.");
        Console.WriteLine();
        Console.ReadLine();

        // Close the ServiceHostBase to shutdown the service.
        serviceHost.Close();
    }
}
Public Shared Sub Main() 
    ' Get base address from appsettings in configuration.
    Dim baseAddress As New Uri(ConfigurationManager.AppSettings("baseAddress"))
    
    ' Create a ServiceHost for the CalculatorService type 
    ' and provide the base address.
    Dim serviceHost As New ServiceHost(GetType(CalculatorService), baseAddress)
    Try
        ' Create a new auditing behavior and set the log location.
        Dim newAudit As New ServiceSecurityAuditBehavior()
        newAudit.AuditLogLocation = AuditLogLocation.Application
        newAudit.MessageAuthenticationAuditLevel = _
            AuditLevel.SuccessOrFailure
        newAudit.ServiceAuthorizationAuditLevel = _
            AuditLevel.SuccessOrFailure
        newAudit.SuppressAuditFailure = False
        ' Remove the old behavior and add the new.
        serviceHost.Description.Behaviors.Remove(Of ServiceSecurityAuditBehavior)
        serviceHost.Description.Behaviors.Add(newAudit)
        ' Open the ServiceHostBase to create listeners 
        ' and start listening for messages.
        serviceHost.Open()
        
        ' The service can now be accessed.
        Console.WriteLine("The service is ready.")
        Console.WriteLine("Press <ENTER> to terminate service.")
        Console.WriteLine()
        Console.ReadLine()
        
        ' Close the ServiceHostBase to shutdown the service.
        serviceHost.Close()
    Finally
    End Try

End Sub 

Commenti

Quando si crea un'applicazione Windows Communication Foundation (WCF) che richiede l'autenticazione e/o l'autorizzazione dei chiamanti, è possibile specificare che gli eventi correlati alla sicurezza vengano registrati in caso di esito positivo, esito negativo o entrambi.When creating a Windows Communication Foundation (WCF) application that requires authentication and/or authorization of callers, you can specify that events related to security be recorded for either success, failure, or both. Il percorso del registro viene determinato in base a questa enumerazione.The location of the log is determined by this enumeration.

Per definire il livello del registro di controllo è possibile impostare la proprietà MessageAuthenticationAuditLevel o la proprietà ServiceAuthorizationAuditLevel della classe ServiceSecurityAuditBehavior su uno dei valori dell'enumerazione AuditLevel.The level of the audit log is specified by setting the MessageAuthenticationAuditLevel or the ServiceAuthorizationAuditLevel property of the ServiceSecurityAuditBehavior class to one of the AuditLevel values.

È inoltre possibile specificare il comportamento di controllo <utilizzando> l'associazione serviceSecurityAudit.You can also specify audit behavior using the <serviceSecurityAudit> binding.

Importante

Se la AuditLogLocation proprietà è impostata su Security e Audit Object Access non Local Security Policyè impostata in, gli eventi di controllo non verranno scritti nel registro di sicurezza.If the AuditLogLocation property is set to Security and Audit Object Access is not set in the Local Security Policy, audit events will not be written to the Security log. Benché non venga restituito alcun errore, le voci di controllo non vengono scritte nel registro sicurezza.No failure is returned, but audit entries will not be written to the Security log. Inoltre, per poter scrivere nel registro sicurezza, il thread chiamante deve disporre del privilegio SeAuditPrivilege.In addition, the calling thread must have SeAuditPrivilege to be able to write to the Security log.

Determinazione del registro predefinito in base al sistema operativoDefault Dependent on Operating System

Quando si imposta la proprietà sul valore predefinito, il sistema operativo determina in quale log verrà effettivamente eseguita la scrittura.When setting the property to the Default value, the operating system determines which log will actually be written to. Per ulteriori informazioni, vedere controllo.For more information, see Auditing.

Si applica a

Vedi anche