Application.SessionEnding Événement

Définition

Se produit quand l’utilisateur met fin à la session Windows en se déconnectant ou en arrêtant le système d’exploitation.Occurs when the user ends the Windows session by logging off or shutting down the operating system.

public:
 event System::Windows::SessionEndingCancelEventHandler ^ SessionEnding;
public event System.Windows.SessionEndingCancelEventHandler SessionEnding;
member this.SessionEnding : System.Windows.SessionEndingCancelEventHandler 
Public Custom Event SessionEnding As SessionEndingCancelEventHandler 

Exemples

L’exemple suivant montre comment gérer l’événement SessionEnding et autoriser l’utilisateur à l’annuler.The following example demonstrates how to handle the SessionEnding event and allow the user to cancel it.

<Application 
    xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
    xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
    x:Class="SDKSample.App"
    StartupUri="MainWindow.xaml"
    SessionEnding="App_SessionEnding" />
using System.Windows;

namespace SDKSample
{
    public partial class App : Application
    {
        void App_SessionEnding(object sender, SessionEndingCancelEventArgs e)
        {
            // Ask the user if they want to allow the session to end
            string msg = string.Format("{0}. End session?", e.ReasonSessionEnding);
            MessageBoxResult result = MessageBox.Show(msg, "Session Ending", MessageBoxButton.YesNo);

            // End session, if specified
            if (result == MessageBoxResult.No)
            {
                e.Cancel = true;
            }
        }
    }
}

Imports System.Windows

Namespace SDKSample
    Partial Public Class App
        Inherits Application
        Private Sub App_SessionEnding(ByVal sender As Object, ByVal e As SessionEndingCancelEventArgs)
            ' Ask the user if they want to allow the session to end
            Dim msg As String = String.Format("{0}. End session?", e.ReasonSessionEnding)
            Dim result As MessageBoxResult = MessageBox.Show(msg, "Session Ending", MessageBoxButton.YesNo)

            ' End session, if specified
            If result = MessageBoxResult.No Then
                e.Cancel = True
            End If
        End Sub
    End Class
End Namespace

Remarques

Par défaut, une application s’arrête lorsque la session Windows se termine, ce qui se produit lorsqu’un utilisateur se déconnecte ou s’arrête.By default, an application shuts down when the Windows session ends, which occurs when a user logs off or shuts down. Dans ce cas, Windows demande à chaque application ouverte de s’arrêter.When this happens, Windows asks each open application to shut down. Toutefois, il est possible qu’une application ne soit pas prête à être arrêtée lorsque cela se produit.However, it is possible that an application may not be ready to shut down when this occurs. Par exemple, une application peut avoir des données qui se trouvent dans un état incohérent ou au milieu d’une opération de longue durée.For example, an application may have data that is in an inconsistent state, or in the middle of a long-running operation. Dans ces situations, il peut être souhaitable d’empêcher la fermeture de la session et peut être plus souhaitable pour permettre aux utilisateurs de décider s’il faut ou non laisser la session se terminer.In these situations, it may be desirable to prevent the session from ending, and may be more desirable to allow users the option to decide whether or not to let the session to end.

Vous pouvez détecter quand une session se termine en gérant l’événement SessionEnding.You can detect when a session ends by handling the SessionEnding event. Si une application doit empêcher la fermeture de la session, l’argument SessionEndingCancelEventArgs qui est passé au gestionnaire d’événements expose les Cancel que vous avez définis sur true (la valeur par défaut est false).If an application needs to prevent the session from ending, the SessionEndingCancelEventArgs argument that is passed to the event handler exposes the Cancel that you set to true (the default value is false).

Si SessionEnding n’est pas gérée, ou est géré sans être annulé, Shutdown est appelée et l’événement Exit est déclenché.If SessionEnding is unhandled, or is handled without being cancelled, Shutdown is called and the Exit event is raised.

Pour obtenir plus d’informations sur la raison pour laquelle la session se termine, une application peut inspecter ReasonSessionEnding, qui est l’une des valeurs ReasonSessionEnding (ReasonSessionEnding.Logoff et ReasonSessionEnding.Shutdown).To obtain more information about why the session is ending, an application can inspect ReasonSessionEnding, which is one of the ReasonSessionEnding values (ReasonSessionEnding.Logoff and ReasonSessionEnding.Shutdown).

SessionEnding n’est pas déclenchée par les applications console.SessionEnding is not raised by console applications.

SessionEnding est déclenchée uniquement sur le thread qui crée l’objet Application.SessionEnding is raised only on the thread that creates the Application object.

SessionEnding n’est pas déclenchée pour les applications de navigateur XAML (XBAP).SessionEnding is not raised for XAML browser applications (XBAPs).

S’applique à

Voir aussi