DefaultHttpHandler Класс

Определение

Представляет свойства и методы обработчика HTTP-данных, заданного по умолчанию.Represents the properties and methods of a default HTTP handler.

public ref class DefaultHttpHandler : System::Web::IHttpAsyncHandler
public class DefaultHttpHandler : System.Web.IHttpAsyncHandler
type DefaultHttpHandler = class
    interface IHttpAsyncHandler
    interface IHttpHandler
Public Class DefaultHttpHandler
Implements IHttpAsyncHandler
Наследование
DefaultHttpHandler
Реализации

Примеры

В следующем примере кода показано, как реализовать настраиваемый обработчик HTTP, производный от DefaultHttpHandler класса.The following code example demonstrates how to implement a customized HTTP handler by deriving from the DefaultHttpHandler class.

public class AsyncDefaultHttpHandler : DefaultHttpHandler
{
    private HttpContext _context;

    public override IAsyncResult BeginProcessRequest(
      HttpContext context, AsyncCallback callback, object state)
    {
        AsyncResultSample ar = new AsyncResultSample(callback, state);
        _context = context;

        return ar;
    }

    public override void EndProcessRequest(IAsyncResult result)
    {
        _context.Response.Write("EndProcessRequest called.");
    }

    // This method should not be called asynchronously.
    public override void ProcessRequest(HttpContext context)
    {
        throw new InvalidOperationException(
                  "Asynchronous processing failed.");
    }

    // Enables pooling when set to true
    public override bool IsReusable
    {
        get { return true; }
    }
}

// Tracks state between the begin and end calls.
class AsyncResultSample : IAsyncResult
{
    private AsyncCallback callback = null;
    private Object asyncState;
    private Boolean isCompleted;

    internal AsyncResultSample(AsyncCallback cb, Object state)
    {
        this.callback = cb;
        asyncState = state;
        isCompleted = false;
    }

    public object AsyncState
    {
        get
        {
            return asyncState;
        }
    }

    public bool CompletedSynchronously
    {
        get
        {
            return false;
        }
    }

    public WaitHandle AsyncWaitHandle
    {
        get
        {
            throw new InvalidOperationException(
                      "ASP.NET should not use this property .");
        }
    }

    public bool IsCompleted
    {
        get
        {
            return isCompleted;
        }
    }

    internal void SetCompleted()
    {
        isCompleted = true;
        if (callback != null)
        {
            callback(this);
        }
    }

}
Public Class defaulthttpexampleVB
    Inherits DefaultHttpHandler

    Private _context As HttpContext

    Public Overrides Function BeginProcessRequest _
        (ByVal context As HttpContext, _
         ByVal callback As AsyncCallback, _
         ByVal state As Object) As IAsyncResult

        Dim ar As New AsyncResultSample(callback, state)
        _context = context

        Return (ar)
    End Function

    Public Overrides Sub EndProcessRequest(ByVal result As IAsyncResult)
        _context.Response.Write("EndProcessRequest called.")
    End Sub

    ' This method should not be called asynchronously.
    Public Overrides Sub ProcessRequest(ByVal context As HttpContext)
        Throw New InvalidOperationException _
          ("Asynchronous processing failed.")
    End Sub

    ' Enables pooling when set to true
    Public Overrides ReadOnly Property IsReusable() As Boolean
        Get
            Return True
        End Get
    End Property
End Class

' Tracks state between the begin and end calls.
Class AsyncResultSample
    Implements IAsyncResult
    Private callback As AsyncCallback = Nothing
    Private _asyncState As Object
    Private _isCompleted As Boolean

    Friend Sub New(ByVal cb As AsyncCallback, ByVal state As Object)
        Me.callback = cb
        _asyncState = state
        _isCompleted = False
    End Sub

    Public ReadOnly Property AsyncState() As Object _
      Implements IAsyncResult.AsyncState
        Get
            Return _asyncState
        End Get
    End Property

    Public ReadOnly Property CompletedSynchronously() _
      As Boolean Implements IAsyncResult.CompletedSynchronously
        Get
            Return False
        End Get
    End Property

    Public ReadOnly Property AsyncWaitHandle() _
      As WaitHandle Implements IAsyncResult.AsyncWaitHandle
        Get
            Throw New InvalidOperationException _
              ("ASP.NET should not use this property .")
        End Get
    End Property

    Public ReadOnly Property IsCompleted() _
      As Boolean Implements IAsyncResult.IsCompleted
        Get
            Return IsCompleted
        End Get
    End Property

    Friend Sub SetCompleted()
        _isCompleted = True
        If (callback <> Nothing) Then
            callback(Me)
        End If
    End Sub
End Class

Комментарии

DefaultHttpHandler Объект перехватывает входящие запросы в конвейере HTTP, когда оба запроса перехватываются с помощью службы IIS (IIS) 6,0, и к запрошенному расширению не применяются явные привязки.A DefaultHttpHandler object intercepts incoming requests in the HTTP pipeline when both request interception has been configured through Internet Information Services (IIS) 6.0 and no explicit bindings apply to the requested extension.

Перехват запросов можно настроить с помощью функции сопоставления приложений с подстановочными знаками, представленной в IIS 6,0.Request interception can be set up through the wildcard application mapping feature introduced in IIS 6.0. Дополнительные сведения см. в библиотеке MSDN , в которой приведены сведения об использовании универсальных схем приложений для сопоставления URL-адресов.For more information, search the MSDN Library for information about using wildcard application maps to remap a URL.

DefaultHttpHandler КлассIHttpAsyncHandler реализует интерфейс, который обеспечивает обработку асинхронных запросов.The DefaultHttpHandler class implements the IHttpAsyncHandler interface to provide asynchronous request processing. Общие сведения о обработчиках HTTP см. в разделе " обработчики HTTP" и "Общиесведения о МОДУЛЯх HTTP".For general information about HTTP handlers, see HTTP Handlers and HTTP Modules Overview. Кроме того, дополнительные сведения см. в следующих статьях:Additionally, for more information see the following:

Классы могут быть производными от DefaultHttpHandler класса для предоставления настраиваемой обработки запросов.Classes can derive from the DefaultHttpHandler class to provide customized handling of requests. Асинхронный обработчик HTTP, производный от, DefaultHttpHandler может BeginProcessRequest переопределить метод для изменения способа обработки запросов.An asynchronous HTTP handler that is derived from the DefaultHttpHandler could override the BeginProcessRequest method to change how requests are processed.

В DefaultHttpHandler не используются ошибки ASP.NET.A DefaultHttpHandler does not use ASP.NET errors. Существующее содержимое, использующее ошибки IIS или собственный механизм специальных ошибок ISAPI, будет работать без изменений.Existing content that uses IIS errors or a propriety ISAPI custom error mechanism would work unchanged.

Конструкторы

DefaultHttpHandler()

Инициализирует новый экземпляр класса DefaultHttpHandler.Initializes a new instance of the DefaultHttpHandler class.

Свойства

Context

Возвращает контекст, связанный с текущим объектом DefaultHttpHandler.Gets the context that is associated with the current DefaultHttpHandler object.

ExecuteUrlHeaders

Возвращает коллекцию заголовков и значений запросов для передачи ее вместе с запросом.Gets a collection of request headers and request values to transfer along with the request.

IsReusable

Возвращает логическое значение, показывающее, что другой запрос может использовать текущий экземпляр класса DefaultHttpHandler.Gets a Boolean value indicating that another request can use the current instance of the DefaultHttpHandler class.

Методы

BeginProcessRequest(HttpContext, AsyncCallback, Object)

Запускает асинхронный вызов обработчика НТТР.Initiates an asynchronous call to the HTTP handler.

EndProcessRequest(IAsyncResult)

Предоставляет метод "End" для асинхронного процесса.Provides an end method for an asynchronous process.

Equals(Object)

Определяет, равен ли указанный объект текущему объекту.Determines whether the specified object is equal to the current object.

(Унаследовано от Object)
GetHashCode()

Служит в качестве хэш-функции по умолчанию.Serves as the default hash function.

(Унаследовано от Object)
GetType()

Возвращает объект Type для текущего экземпляра.Gets the Type of the current instance.

(Унаследовано от Object)
MemberwiseClone()

Создает неполную копию текущего объекта Object.Creates a shallow copy of the current Object.

(Унаследовано от Object)
OnExecuteUrlPreconditionFailure()

Вызывается, когда предварительные условия препятствуют обработке запроса объектом DefaultHttpHandler.Called when preconditions prevent the DefaultHttpHandler object from processing a request.

OverrideExecuteUrlPath()

Переопределяет целевой URL-адрес для текущего запроса.Overrides the target URL for the current request.

ProcessRequest(HttpContext)

Включает объект DefaultHttpHandler для обработки веб-запросов HTTP.Enables a DefaultHttpHandler object to process of HTTP Web requests.

ToString()

Возвращает строку, представляющую текущий объект.Returns a string that represents the current object.

(Унаследовано от Object)

Применяется к

Дополнительно