DefaultHttpHandler Classe
Definição
Importante
Algumas informações dizem respeito a um produto pré-lançado que pode ser substancialmente modificado antes de ser lançado. A Microsoft não faz garantias, de forma expressa ou implícita, em relação à informação aqui apresentada.
Representa as propriedades e métodos de um manipulador HTTP por defeito.
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
- Herança
-
DefaultHttpHandler
- Implementações
Exemplos
O exemplo de código seguinte demonstra como implementar um handler HTTP personalizado derivando da DefaultHttpHandler classe.
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
Observações
Um objeto DefaultHttpHandler interceta pedidos recebidos no pipeline HTTP quando ambas as interceções de pedidos foram configuradas através do Serviços de Informação Internet (IIS) 6.0 e não se aplicam ligações explícitas à extensão solicitada.
A interceção de pedidos pode ser configurada através da funcionalidade de mapeamento de aplicações curinga introduzida no IIS 6.0.
A DefaultHttpHandler classe implementa a IHttpAsyncHandler interface para fornecer processamento assíncrono de pedidos. Para informações gerais sobre os manipuladores HTTP, consulte Visão Geral dos Manipuladores HTTP e dos Módulos HTTP. Além disso, para mais informações, veja o seguinte:
Sobre a criação de handlers HTTP assíncronos, veja Walkthrough: Creating an Asynchronous HTTP Handler.
Sobre o registo de handlers HTTP, veja Como: Registar Handlers HTTP.
As classes podem derivar da DefaultHttpHandler classe para proporcionar um tratamento personalizado dos pedidos. Um manipulador HTTP assíncrono derivado do DefaultHttpHandler poderia sobrepor o BeginProcessRequest método para alterar a forma como os pedidos são processados.
Um DefaultHttpHandler não utiliza erros ASP.NET. Conteúdos existentes que utilizam erros IIS ou um mecanismo personalizado de erro ISAPI funcionaria sem alterações.
Construtores
| Name | Description |
|---|---|
| DefaultHttpHandler() |
Inicializa uma nova instância da DefaultHttpHandler classe. |
Propriedades
| Name | Description |
|---|---|
| Context |
Obtém o contexto associado ao objeto atual DefaultHttpHandler . |
| ExecuteUrlHeaders |
Recebe uma coleção de cabeçalhos e valores de pedido para transferir juntamente com o pedido. |
| IsReusable |
Recebe um valor Booleano que indica que outro pedido pode usar a instância atual da DefaultHttpHandler classe. |
Métodos
| Name | Description |
|---|---|
| BeginProcessRequest(HttpContext, AsyncCallback, Object) |
Inicia uma chamada assíncrona para o handler HTTP. |
| EndProcessRequest(IAsyncResult) |
Fornece um método final para um processo assíncrono. |
| Equals(Object) |
Determina se o objeto especificado é igual ao objeto atual. (Herdado de Object) |
| GetHashCode() |
Serve como função de hash predefinida. (Herdado de Object) |
| GetType() |
Obtém o Type da instância atual. (Herdado de Object) |
| MemberwiseClone() |
Cria uma cópia superficial do atual Object. (Herdado de Object) |
| OnExecuteUrlPreconditionFailure() |
Chamado quando as pré-condições impedem o DefaultHttpHandler objeto de processar um pedido. |
| OverrideExecuteUrlPath() |
Sobrepõe a URL de destino do pedido atual. |
| ProcessRequest(HttpContext) |
Permite que um DefaultHttpHandler objeto processe pedidos Web HTTP. |
| ToString() |
Devolve uma cadeia que representa o objeto atual. (Herdado de Object) |