IHttpContext::CloneContext, méthode
Crée un clone du contexte de requête actuel.
Syntaxe
virtual HRESULT CloneContext(
IN DWORD dwCloneFlags,
OUT IHttpContext** ppHttpContext
) = 0;
Paramètres
dwCloneFlags
[IN] DWORD
qui contient les indicateurs de clone.
ppHttpContext
[OUT] Pointeur déréférencé vers un IHttpContext.
Valeur renvoyée
Élément HRESULT
. Les valeurs possibles sont notamment celles figurant dans le tableau suivant.
Valeur | Description |
---|---|
S_OK | Indique que l’opération a réussi. |
ERROR_INVALID_PARAMETER | Indique qu’un paramètre spécifié n’était pas valide. |
ERROR_NOT_ENOUGH_MEMORY | Indique que la mémoire est insuffisante pour effectuer l’opération. |
Remarques
La CloneContext
méthode crée un clone du contexte de requête actuel. Vous pouvez contrôler le comportement de clonage en spécifiant les indicateurs appropriés dans le dwCloneFlags
paramètre . Le tableau suivant répertorie les valeurs possibles pour ces indicateurs.
Valeur | Description |
---|---|
CLONE_FLAG_BASICS | Clonez l’URL, la chaîne de requête et la méthode HTTP. |
CLONE_FLAG_HEADERS | Clonez les en-têtes de requête. |
CLONE_FLAG_ENTITY | Clonez le corps de l’entité. |
CLONE_FLAG_NO_PRECONDITION | N’incluez pas d’en-têtes « range » et « if- » pour la demande. |
CLONE_FLAG_NO_DAV | N’incluez aucun en-tête WebDAV pour la demande. |
Une fois que vous avez créé un contexte cloné, vous pouvez utiliser le clone comme vous le feriez pour le contexte parent. Par exemple, pour exécuter une requête enfant pour une URL différente de celle de l’URL parente, vous devez utiliser la méthode IHttpRequest::SetUrl pour le contexte cloné afin de modifier l’URL du contexte cloné avant d’appeler la méthode IHttpContext::ExecuteRequest du contexte parent.
Exemple
L’exemple de code suivant montre comment créer un module HTTP qui effectue les tâches suivantes :
Le module s’inscrit pour la notification RQ_MAP_PATH .
Le module crée une classe CHttpModule qui contient les méthodes OnMapPath et OnAsyncCompletion .
Lorsqu’un client Web demande une URL, IIS appelle la méthode du
OnMapPath
module. Cette méthode effectue les tâches suivantes :Teste pour voir si l’URL de la requête actuelle a une barre oblique de fin ou se termine par /default.aspx. Si l’URL se termine par l’un ou l’autre élément, le module utilise la
CloneContext
méthode pour créer un clone de la requête actuelle.Appelle la méthode du
IHttpRequest::SetUrl
clone pour définir l’URL du clone sur /example/default.aspx.Appelle la
IHttpContext::ExecuteRequest
méthode pour exécuter la requête enfant.Teste l’achèvement asynchrone. Si l’achèvement asynchrone est en attente, le module retourne le traitement au pipeline de traitement des demandes intégré. Si ce n’est pas le cas, le module libère le contexte cloné.
Si la saisie semi-automatique est requise, IIS appelle la méthode du
OnAsyncCompletion
module. Cette méthode libère le contexte cloné.Le module supprime la classe de la
CHttpModule
mémoire, puis se ferme.
#define _WINSOCKAPI_
#include <windows.h>
#include <sal.h>
#include <httpserv.h>
// Create the module class.
class MyHttpModule : public CHttpModule
{
private:
// Create a pointer for a child request.
IHttpContext * m_pChildRequestContext;
public:
MyHttpModule(void)
{
m_pChildRequestContext = NULL;
}
REQUEST_NOTIFICATION_STATUS
OnMapPath(
IN IHttpContext * pHttpContext,
IN IMapPathProvider * pProvider
)
{
UNREFERENCED_PARAMETER( pProvider );
HRESULT hr;
BOOL fCompletionExpected;
// Retrieve a pointer to the URL.
PCWSTR pwszUrl = pProvider->GetUrl();
// Only process requests for the root.
if (0 == wcscmp(pwszUrl,L"/") || 0 == wcscmp(pwszUrl,L"/default.aspx"))
{
// Clone the current context.
hr = pHttpContext->CloneContext(
CLONE_FLAG_BASICS, &m_pChildRequestContext );
// Test for a failure.
if (FAILED(hr))
{
goto Failure;
}
// Test for an error.
if ( NULL != m_pChildRequestContext )
{
// Set the URL for the child request.
hr = m_pChildRequestContext->GetRequest()->SetUrl(
"/example/default.aspx",
(DWORD)strlen("/example/default.aspx"),false);
// Test for a failure.
if (FAILED(hr))
{
goto Failure;
}
// Execute the child request.
hr = pHttpContext->ExecuteRequest(
TRUE, m_pChildRequestContext,
0, NULL, &fCompletionExpected );
// Test for a failure.
if (FAILED(hr))
{
goto Failure;
}
// Test for pending asynchronous operations.
if (fCompletionExpected)
{
return RQ_NOTIFICATION_PENDING;
}
}
Failure:
// Test for a child request.
if (NULL != m_pChildRequestContext)
{
// Release the child request.
m_pChildRequestContext->ReleaseClonedContext();
m_pChildRequestContext = NULL;
}
}
// Return processing to the pipeline.
return RQ_NOTIFICATION_CONTINUE;
}
REQUEST_NOTIFICATION_STATUS
OnAsyncCompletion(
IN IHttpContext * pHttpContext,
IN DWORD dwNotification,
IN BOOL fPostNotification,
IN IHttpEventProvider * pProvider,
IN IHttpCompletionInfo * pCompletionInfo
)
{
// Test for a child request.
if (NULL != m_pChildRequestContext)
{
// Release the child request.
m_pChildRequestContext->ReleaseClonedContext();
m_pChildRequestContext = NULL;
}
// Return processing to the pipeline.
return RQ_NOTIFICATION_CONTINUE;
}
};
// Create the module's class factory.
class MyHttpModuleFactory : public IHttpModuleFactory
{
public:
HRESULT
GetHttpModule(
OUT CHttpModule ** ppModule,
IN IModuleAllocator * pAllocator
)
{
UNREFERENCED_PARAMETER( pAllocator );
// Create a new instance.
MyHttpModule * pModule = new MyHttpModule;
// Test for an error.
if (!pModule)
{
// Return an error if we cannot create the instance.
return HRESULT_FROM_WIN32( ERROR_NOT_ENOUGH_MEMORY );
}
else
{
// Return a pointer to the module.
*ppModule = pModule;
pModule = NULL;
// Return a success status.
return S_OK;
}
}
void Terminate()
{
// Remove the class from memory.
delete this;
}
};
// Create the module's exported registration function.
HRESULT
__stdcall
RegisterModule(
DWORD dwServerVersion,
IHttpModuleRegistrationInfo * pModuleInfo,
IHttpServer * pGlobalInfo
)
{
UNREFERENCED_PARAMETER( dwServerVersion );
UNREFERENCED_PARAMETER( pGlobalInfo );
return pModuleInfo->SetRequestNotifications(
new MyHttpModuleFactory,
RQ_MAP_PATH,
0
);
}
Votre module doit exporter la fonction RegisterModule . Vous pouvez exporter cette fonction en créant un fichier de définition de module (.def) pour votre projet, ou vous pouvez compiler le module à l’aide du /EXPORT:RegisterModule
commutateur . Pour plus d’informations, consultez Procédure pas à pas : création d’un module HTTP Request-Level à l’aide de code natif.
Vous pouvez éventuellement compiler le code à l’aide de la __stdcall (/Gz)
convention d’appel au lieu de déclarer explicitement la convention d’appel pour chaque fonction.
Spécifications
Type | Description |
---|---|
Client | - IIS 7.0 sur Windows Vista - IIS 7.5 sur Windows 7 - IIS 8.0 sur Windows 8 - IIS 10.0 sur Windows 10 |
Serveur | - IIS 7.0 sur Windows Server 2008 - IIS 7.5 sur Windows Server 2008 R2 - IIS 8.0 sur Windows Server 2012 - IIS 8.5 sur Windows Server 2012 R2 - IIS 10.0 sur Windows Server 2016 |
Produit | - IIS 7.0, IIS 7.5, IIS 8.0, IIS 8.5, IIS 10.0 - IIS Express 7.5, IIS Express 8.0, IIS Express 10.0 |
En-tête | Httpserv.h |
Voir aussi
IHttpContext, interface
IHttpContext::ExecuteRequest, méthode
IHttpContext::ReleaseClonedContext, méthode