Método IHttpResponse::GetErrorDescription
Recupera a descrição do erro personalizada.
Sintaxe
virtual PCWSTR GetErrorDescription(
OUT DWORD* pcchDescription = NULL
) = 0;
Parâmetros
pcchDescription
[OUT] Um ponteiro para um DWORD
valor que contém o comprimento, em caracteres, da cadeia de caracteres retornada.
Valor Retornado
Um ponteiro para uma cadeia de caracteres que contém a descrição de erro personalizada.
Comentários
Os desenvolvedores usam o GetErrorDescription
método para recuperar a descrição de erro personalizada. O IIS exibe a descrição de erro personalizada como parte das informações detalhadas enviadas a um cliente Web quando o IIS retorna uma mensagem de erro.
Exemplo
O exemplo de código a seguir demonstra como criar um módulo HTTP que executa as seguintes tarefas:
Recupera um ponteiro para uma interface IHttpResponse usando o método IHttpContext::GetResponse .
Recupera o código http status atual usando o método IHttpResponse::GetStatus.
Se o código HTTP status atual for um erro 404.0, recuperará a descrição de erro personalizada atual usando o
GetErrorDescription
método .Se nenhuma descrição de erro personalizada estiver definida no momento, definirá a descrição do erro personalizada usando o método IHttpResponse::SetErrorDescription .
#define _WINSOCKAPI_
#include <windows.h>
#include <sal.h>
#include <httpserv.h>
// Create the module class.
class MyHttpModule : public CHttpModule
{
public:
REQUEST_NOTIFICATION_STATUS
OnSendResponse(
IN IHttpContext * pHttpContext,
IN ISendResponseProvider * pProvider
)
{
UNREFERENCED_PARAMETER( pProvider );
// Retrieve a a pointer to the current response.
IHttpResponse * pHttpResponse = pHttpContext->GetResponse();
// Test for errors.
if (NULL != pHttpResponse)
{
USHORT uStatusCode = 0;
USHORT uSubStatus = 0;
// Retrieve the current HTTP status code.
pHttpResponse->GetStatus(&uStatusCode,&uSubStatus);
// Process only 404.0 errors.
if (uStatusCode==404 && uSubStatus==0)
{
DWORD cchDescription = 0;
// Retrieve the current error description.
PCWSTR pwszErrorDescription =
pHttpResponse->GetErrorDescription(&cchDescription);
// Process only if no error description is currently defined.
if (cchDescription==0)
{
// Define the new error description.
PCWSTR wszNewDescription =
L"The file that you requested cannot be found.";
// Configure the new error description.
pHttpResponse->SetErrorDescription(
wszNewDescription,wcslen(wszNewDescription),TRUE);
}
}
}
// 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_SEND_RESPONSE,
0
);
}
Seu módulo deve exportar a função RegisterModule . Você pode exportar essa função criando um arquivo de definição de módulo (.def) para seu projeto ou pode compilar o módulo usando a opção /EXPORT:RegisterModule
. Para obter mais informações, consulte Passo a passo: criando um módulo HTTP Request-Level usando código nativo.
Opcionalmente, você pode compilar o código usando a __stdcall (/Gz)
convenção de chamada em vez de declarar explicitamente a convenção de chamada para cada função.
Requisitos
Type | Descrição |
---|---|
Cliente | - IIS 7.0 no Windows Vista - IIS 7.5 no Windows 7 - IIS 8.0 no Windows 8 - IIS 10.0 no Windows 10 |
Servidor | - IIS 7.0 no Windows Server 2008 - IIS 7.5 no Windows Server 2008 R2 - IIS 8.0 no Windows Server 2012 - IIS 8.5 no Windows Server 2012 R2 - IIS 10.0 no Windows Server 2016 |
Produto | - 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 |
parâmetro | Httpserv.h |
Consulte Também
IHttpResponse Interface
Método IHttpResponse::SetErrorDescription