Udostępnij za pośrednictwem


HttpContext.IsPostNotification Właściwość

Definicja

Pobiera wartość, która jest bieżącym punktem przetwarzania w potoku ASP.NET tuż po HttpApplication zakończeniu przetwarzania zdarzenia.

public:
 property bool IsPostNotification { bool get(); };
public bool IsPostNotification { get; }
member this.IsPostNotification : bool
Public ReadOnly Property IsPostNotification As Boolean

Wartość właściwości

Boolean

true jeśli są włączone błędy niestandardowe; w przeciwnym razie , false.

Wyjątki

Operacja wymaga zintegrowanego trybu potoku w usługach IIS 7.0 i co najmniej .NET Framework 3.0.

Przykłady

W poniższym przykładzie pokazano, jak za pomocą IsPostNotification właściwości określić, kiedy zdarzenie obiektu zakończyło przetwarzanie wszystkich skojarzonych HttpApplication programów obsługi zdarzeń. Niestandardowa procedura obsługi zdarzeń w tym przykładzie obsługuje kilka zdarzeń HttpApplication obiektu, a IsPostNotification właściwość jest używana do określania, jaki kod jest wywoływany po obsłużeniu określonego zdarzenia.

using System;
using System.Data;
using System.Web;
using System.Web.Security;
using System.Web.UI;

// Module that demonstrates one event handler for several events.
namespace Samples
{
    public class ModuleExampleTestCS : IHttpModule
    {
        public ModuleExampleTestCS()
        {
            // Constructor
        }
        public void Init(HttpApplication app)
        {
            app.AuthenticateRequest += new EventHandler(App_Handler);
            app.PostAuthenticateRequest += new EventHandler(App_Handler);
            app.LogRequest += new EventHandler(App_Handler);
            app.PostLogRequest += new EventHandler(App_Handler);
        }
        public void Dispose()
        {
        }
        // One handler for AuthenticationRequest, PostAuthenticateRequest,
    // LogRequest, and PostLogRequest events
        public void App_Handler(object source, EventArgs e)
        {
            HttpApplication app = (HttpApplication)source;
            HttpContext context = app.Context;

            if (context.CurrentNotification == RequestNotification.AuthenticateRequest)
            {

                if (!context.IsPostNotification)
                {
                    // Put code here that is invoked when the AuthenticateRequest event is raised.
                }
                else
                {
                    // PostAuthenticateRequest 
                    // Put code here that runs after the AuthenticateRequest event completes.
                }
            }
            if (context.CurrentNotification == RequestNotification.LogRequest)
            {
                if (!context.IsPostNotification)
                {
                    // Put code here that is invoked when the LogRequest event is raised.
                }
                else
                {
                    // PostLogRequest
                    // Put code here that runs after the LogRequest event completes.
                }
            }
        }
    }
}
Imports System.Data
Imports System.Web
Imports System.Web.Security
Imports System.Web.UI

' Module that demonstrates one event handler for several events.
Namespace Samples

    Public Class ModuleExampleTestVB
        Implements IHttpModule

        Public Sub New()
            ' Constructor
        End Sub

        Public Sub Init(ByVal app As HttpApplication) Implements IHttpModule.Init
            AddHandler app.AuthenticateRequest, AddressOf Me.App_Handler
            AddHandler app.PostAuthenticateRequest, AddressOf Me.App_Handler
            AddHandler app.LogRequest, AddressOf Me.App_Handler
            AddHandler app.PostLogRequest, AddressOf Me.App_Handler
        End Sub

        Public Sub Dispose() Implements IHttpModule.Dispose
        End Sub

        ' One handler for AuthenticationRequest, PostAuthenticateRequest,
    ' LogRequest, and PostLogRequest events
        Public Sub App_Handler(ByVal source As Object, ByVal e As EventArgs)
            Dim app As HttpApplication = CType(source, HttpApplication)
            Dim context As HttpContext = app.Context

            If (context.CurrentNotification = RequestNotification.AuthenticateRequest) Then

                If Not (context.IsPostNotification) Then

                    ' Put code here that is invoked when the AuthenticateRequest event is raised.
                Else

                    ' PostAuthenticateRequest 
                    ' Put code here that runs after the AuthenticateRequest event completes.

                End If
            End If

            If (context.CurrentNotification = RequestNotification.LogRequest) Then

                If Not (context.IsPostNotification) Then

                    ' Put code here that is invoked when the LogRequest event is raised.

                Else
                    ' PostLogRequest
                    ' Put code here that runs after the LogRequest event completes.

                End If
            End If
        End Sub
    End Class

End Namespace

Uwagi

Właściwość jest obsługiwana IsPostNotification tylko w trybie zintegrowanym w usługach IIS 7.0 i co najmniej .NET Framework 3.0. Gdy jest dostępna, właściwość zwraca wartość logiczną wskazującą, czy zdarzenie w HttpApplication obiekcie zakończyło przetwarzanie.

Właściwość nie jest przeznaczona IsPostNotification do ustawienia. Zamiast tego jest on dostarczany przez usługi IIS 7.0 do środowiska uruchomieniowego ASP.NET dla każdego powiadomienia. IsPostNotification Ustawienie właściwości spowoduje błąd kompilacji.

W scenariuszach, w których wiele zdarzeń HttpApplication obiektu jest obsługiwanych przez jedną procedurę obsługi zdarzeń, można użyć IsPostNotification właściwości w połączeniu RequestNotification z wyliczeniem, aby dokładnie określić, gdzie w cyklu życia aplikacji znajduje się bieżące żądanie.

IsPostNotificationjest wprowadzana w wersji .NET Framework 3.5. Aby uzyskać więcej informacji, zobacz Wersje i zależności.

Dotyczy

Zobacz też