Oharra
Baimena behar duzu orria atzitzeko. Direktorioetan saioa has dezakezu edo haiek alda ditzakezu.
Baimena behar duzu orria atzitzeko. Direktorioak alda ditzakezu.
Escribe un mensaje en el registro de seguimiento de IIS.
Sintaxis
virtual
HRESULT
QuickTrace(
IN PCWSTR pszData1,
IN PCWSTR pszData2 = NULL,
IN HRESULT hrLastError = S_OK,
IN UCHAR Level = 4
) = 0;
Parámetros
| Parámetro | Descripción |
|---|---|
pszData1 |
Mensaje que se va a registrar. |
pszData2 |
Un segundo mensaje que se va a registrar. |
hrLastError |
que HRESULT se va a registrar. El valor predeterminado es S_OK. |
level |
Nivel de seguimiento. Los valores posibles son de 1 a 7. El valor predeterminado es 4 (TRACE_LEVEL_INFORMATION). Para obtener más información, vea la sección Comentarios. |
Valor devuelto
Una clase HRESULT. Entre los valores posibles se incluyen los que se indican en la tabla siguiente, entre otros.
| Value | Descripción |
|---|---|
| S_OK | Indica que la operación se realizó correctamente. |
Comentarios
Los niveles de seguimiento de eventos de 1 a 5 corresponden a los niveles de seguimiento de Seguimiento de eventos para Windows (ETW). Para obtener más información sobre estos niveles de seguimiento, consulte la estructura EVENT_TRACE_HEADER . También puede usar el nivel de seguimiento 6 (definido como HTTP_TRACE_LEVEL_START en el archivo de encabezado Httptrace.h) y el nivel de seguimiento 7 (definido como HTTP_TRACE_LEVEL_END en Httptrace.h).
Ejemplo
En el ejemplo siguiente se muestra cómo usar el método IHttpRequest::SetUrl para cambiar una dirección URL solicitada a otra dirección URL y registrar el cambio con el QuickTrace método .
Debe habilitar el seguimiento de solicitudes de eventos con error para ver el evento.
HRESULT GLOBAL_MODULE::Initialize( VOID ){
return S_OK;
}
// CGlobalModule derived classes must implement Terminate
// And free memory
//
VOID GLOBAL_MODULE::Terminate( VOID){
delete this;
}
GLOBAL_NOTIFICATION_STATUS
GLOBAL_MODULE::OnGlobalPreBeginRequest(
IPreBeginRequestProvider* pProvider
)
{
HRESULT hr = S_OK;
IHttpContext* pContext = pProvider->GetHttpContext( );
IHttpRequest* pRequest = pContext->GetRequest( );
IHttpResponse* pResponse = pContext->GetResponse( );
PCWSTR rqUrl = pContext->GetRequest()->GetRawHttpRequest()->CookedUrl.pAbsPath;
OutputDebugStringW(rqUrl);
//
// Change only specific URL requests.
//
wchar_t URLask[] = L"/rPost.htm";
wchar_t URLreset[] = L"/Test.htm";
if(!wcscmp(rqUrl,URLask)){
hr = pRequest->SetUrl( URLreset, sizeof( URLreset )/sizeof(URLreset[0]) - 1, TRUE );
pContext->GetTraceContext( )->QuickTrace( L"URL change from rPost to", URLreset );
}
if( FAILED( hr ) )
goto Finished;
Finished:
if( FAILED( hr ) ){
pResponse->SetStatus( 500, "Internal Server Error", 0, hr );
return GL_NOTIFICATION_HANDLED;
}
return GL_NOTIFICATION_CONTINUE;
}
/*
#include "stdafx.h"
HRESULT GLOBAL_MODULE::Initialize( VOID ){
return S_OK;
}
// CGlobalModule derrived classes must implement Terminate
// And free memory
//
VOID GLOBAL_MODULE::Terminate( VOID){
delete this;
}
GLOBAL_NOTIFICATION_STATUS
GLOBAL_MODULE::OnGlobalPreBeginRequest(
IPreBeginRequestProvider* pProvider
)
{
HRESULT hr = S_OK;
IHttpContext* pContext = pProvider->GetHttpContext( );
IHttpRequest* pRequest = pContext->GetRequest( );
IHttpResponse* pResponse = pContext->GetResponse( );
PCWSTR rqUrl = pContext->GetRequest()->GetRawHttpRequest()->CookedUrl.pAbsPath;
OutputDebugStringW(rqUrl);
//
// Change only specific URL requests.
//
wchar_t URLask[] = L"/rPost.htm";
wchar_t URLreset[] = L"/Test.htm";
if(!wcscmp(rqUrl,URLask)){
hr = pRequest->SetUrl( URLreset, sizeof( URLreset )/sizeof(URLreset[0]) - 1, TRUE );
pContext->GetTraceContext( )->QuickTrace( L"URL change to test " );
}
if( FAILED( hr ) )
goto Finished;
Finished:
if( FAILED( hr ) ){
pResponse->SetStatus( 500, "Internal Server Error", 0, hr );
// returning GL_NOTIFICATION_HANDLED means end the request
return GL_NOTIFICATION_HANDLED;
}
return GL_NOTIFICATION_CONTINUE;
}
*/
int _tmain(int argc, _TCHAR* argv[])
{
printf("It works!");
return 0;
}
#define _WINSOCKAPI_
#include <windows.h>
#include <sal.h>
#include <httpserv.h>
// Create the module class.
class MyHttpModule : public CHttpModule
{
public:
REQUEST_NOTIFICATION_STATUS
OnBeginRequest(
IN IHttpContext * pHttpContext,
IN IHttpEventProvider * pProvider
)
{
UNREFERENCED_PARAMETER( pProvider );
// Retrieve a pointer to the request.
IHttpRequest * pHttpRequest = pHttpContext->GetRequest();
// Test for an error.
if (pHttpRequest != NULL)
{
// Specify an OPTIONS request method.
HRESULT hr = pHttpRequest->SetHttpMethod("OPTIONS");
// Test for an error.
if (FAILED(hr))
{
// Set the error status.
pProvider->SetErrorStatus( hr );
// End additional processing.
return RQ_NOTIFICATION_FINISH_REQUEST;
}
}
// 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 the factory 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 );
// Set the request notifications and exit.
return pModuleInfo->SetRequestNotifications(
new MyHttpModuleFactory,
RQ_BEGIN_REQUEST,
0
);
}
Requisitos
| Tipo | Descripción |
|---|---|
| Remoto | - IIS 7.0 en Windows Vista - IIS 7.5 en Windows 7 - IIS 8.0 en Windows 8 - IIS 10.0 en Windows 10 |
| Servidor | - IIS 7.0 en Windows Server 2008 - IIS 7.5 en Windows Server 2008 R2 - IIS 8.0 en Windows Server 2012 - IIS 8.5 en Windows Server 2012 R2 - IIS 10.0 en Windows Server 2016 |
| Producto | - 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 |
| Encabezado | Httpserv.h |