DefaultHttpHandler Classe
Définition
Important
Certaines informations portent sur la préversion du produit qui est susceptible d’être en grande partie modifiée avant sa publication. Microsoft exclut toute garantie, expresse ou implicite, concernant les informations fournies ici.
Représente les propriétés et les méthodes d'un gestionnaire HTTP par défaut.
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
- Héritage
-
DefaultHttpHandler
- Implémente
Exemples
L’exemple de code suivant montre comment implémenter un gestionnaire HTTP personnalisé en dérivant de la 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
Remarques
Un DefaultHttpHandler objet intercepte les requêtes entrantes dans le pipeline HTTP lorsque les deux interceptions de requêtes ont été configurées via Internet Information Services (IIS) 6.0 et qu’aucune liaison explicite ne s’applique à l’extension demandée.
L’interception des demandes peut être configurée via la fonctionnalité de mappage d’application générique introduite dans IIS 6.0.
La DefaultHttpHandler classe implémente l’interface IHttpAsyncHandler pour fournir un traitement asynchrone des requêtes. Pour obtenir des informations générales sur les gestionnaires HTTP, consultez Vue d’ensemble des gestionnaires HTTP et des modules HTTP. En outre, pour plus d’informations, consultez les rubriques suivantes :
À propos de la création de gestionnaires HTTP asynchrones, consultez Procédure pas à pas : création d’un gestionnaire HTTP asynchrone.
À propos de l’inscription des gestionnaires HTTP, consultez Guide pratique pour inscrire des gestionnaires HTTP.
Les classes peuvent dériver de la DefaultHttpHandler classe pour fournir une gestion personnalisée des requêtes. Un gestionnaire HTTP asynchrone dérivé de peut DefaultHttpHandler remplacer la méthode pour modifier le BeginProcessRequest mode de traitement des demandes.
Un DefaultHttpHandler n’utilise pas les erreurs ASP.NET. Le contenu existant qui utilise des erreurs IIS ou un mécanisme d’erreur personnalisé ISAPI approprié fonctionnerait inchangé.
Constructeurs
DefaultHttpHandler() |
Initialise une nouvelle instance de la classe DefaultHttpHandler. |
Propriétés
Context |
Obtient le contexte associé à l'objet DefaultHttpHandler actuel. |
ExecuteUrlHeaders |
Obtient qu'une collection d'en-têtes de demande et de valeurs de demande à transférer avec la demande. |
IsReusable |
Obtient une valeur Boolean indiquant qu'une autre demande peut utiliser l'instance actuelle de la classe DefaultHttpHandler. |
Méthodes
BeginProcessRequest(HttpContext, AsyncCallback, Object) |
Lance un appel asynchrone au gestionnaire HTTP. |
EndProcessRequest(IAsyncResult) |
Fournit une méthode End pour un processus asynchrone. |
Equals(Object) |
Détermine si l'objet spécifié est égal à l'objet actuel. (Hérité de Object) |
GetHashCode() |
Fait office de fonction de hachage par défaut. (Hérité de Object) |
GetType() |
Obtient le Type de l'instance actuelle. (Hérité de Object) |
MemberwiseClone() |
Crée une copie superficielle du Object actuel. (Hérité de Object) |
OnExecuteUrlPreconditionFailure() |
Appelé lorsque les conditions préalables empêchent l'objet DefaultHttpHandler de traiter une demande. |
OverrideExecuteUrlPath() |
Substitue l'URL cible de la demande actuelle. |
ProcessRequest(HttpContext) |
Active un objet DefaultHttpHandler pour traiter des demandes Web HTTP. |
ToString() |
Retourne une chaîne qui représente l'objet actuel. (Hérité de Object) |