Application.SessionEnding Application.SessionEnding Application.SessionEnding Application.SessionEnding Event

Definition

Tritt ein, wenn ein Benutzer die Windows-Sitzung beendet, indem er sich abmeldet oder das Betriebssystem herunterfährt.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 

Beispiele

Das folgende Beispiel zeigt, wie Sie behandelt die SessionEnding Ereignis und ermöglicht dem Benutzer, ihn abzubrechen.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 Microsoft.VisualBasic
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

Hinweise

Standardmäßig wird eine Anwendung beendet, wenn die Windows-Sitzung beendet, das auftritt, wenn ein Benutzer ab- oder wird heruntergefahren.By default, an application shuts down when the Windows session ends, which occurs when a user logs off or shuts down. In diesem Fall fordert Windows jede geöffnete Anwendung heruntergefahren.When this happens, Windows asks each open application to shut down. Allerdings ist es möglich, dass eine Anwendung möglicherweise nicht zum Herunterfahren in diesem Fall bereit.However, it is possible that an application may not be ready to shut down when this occurs. Beispielsweise kann eine Anwendung Daten enthalten, die in einem inkonsistenten Zustand, oder klicken Sie in der Mitte einer lang andauernden Vorgang ist.For example, an application may have data that is in an inconsistent state, or in the middle of a long-running operation. In diesen Situationen kann wünschenswert sein, zu verhindern, dass die Sitzung beendet, dabei möglicherweise sinnvoller ist, können Benutzer entscheiden, ob die Sitzung beendet wird oder nicht.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.

Sie können erkennen, wenn eine Sitzung beendet wird, durch Behandeln der SessionEnding Ereignis.You can detect when a session ends by handling the SessionEnding event. Wenn eine Anwendung benötigt, um zu verhindern, dass die Sitzung beendet, die SessionEndingCancelEventArgs an den Ereignishandler übergebene Argument stellt die Cancel , die Sie festlegen, um true (der Standardwert ist 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).

Wenn SessionEnding nicht behandelt wird oder ohne Abbruch, behandelt wird Shutdown aufgerufen wird und die Exit Ereignis wird ausgelöst.If SessionEnding is unhandled, or is handled without being cancelled, Shutdown is called and the Exit event is raised.

Um erhalten weitere Informationen, warum die Sitzung beendet wird, eine Anwendung kann überprüfen ReasonSessionEnding, einer der der ReasonSessionEnding Werte (ReasonSessionEnding.Logoff und 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 wird von der konsolenanwendungen nicht ausgelöst.SessionEnding is not raised by console applications.

SessionEnding wird ausgelöst, nur auf der Thread, erstellt die Application Objekt.SessionEnding is raised only on the thread that creates the Application object.

SessionEnding für XAML-Browseranwendungen (XBAPs) wird nicht ausgelöst werden.SessionEnding is not raised for XAML browser applications (XBAPs).

Gilt für:

Siehe auch