Recuperando mensagens de erro
Quando uma chamada de método produz um erro, muitas funções retornam um código de erro. Para a maioria das interfaces e elementos de API dos Serviços de Certificado que retornam um código de erro, o texto da mensagem de erro pode ser recuperado chamando FormatMessage com um identificador de módulo NULL . Se FormatMessage não for bem-sucedido, o código de erro provavelmente resultará de um elemento de API de backup ou erro relacionado ao banco de dados; chamando FormatMessage com um identificador de módulo correspondente à biblioteca de Ntdsbmsg.dll deve recuperar o texto da mensagem de erro. O exemplo a seguir mostra como recuperar o texto da mensagem de erro em um aplicativo dos Serviços de Certificados.
#include <windows.h>
#include <stdio.h>
// Display error message text, given an error code.
// Typically, the parameter passed to this function is retrieved
// from GetLastError().
void PrintCSBackupAPIErrorMessage(DWORD dwErr)
{
WCHAR wszMsgBuff[512]; // Buffer for text.
DWORD dwChars; // Number of chars returned.
// Try to get the message from the system errors.
dwChars = FormatMessage( FORMAT_MESSAGE_FROM_SYSTEM |
FORMAT_MESSAGE_IGNORE_INSERTS,
NULL,
dwErr,
0,
wszMsgBuff,
512,
NULL );
if (0 == dwChars)
{
// The error code did not exist in the system errors.
// Try Ntdsbmsg.dll for the error code.
HINSTANCE hInst;
// Load the library.
hInst = LoadLibrary(L"Ntdsbmsg.dll");
if ( NULL == hInst )
{
printf("cannot load Ntdsbmsg.dll\n");
exit(1); // Could 'return' instead of 'exit'.
}
// Try getting message text from ntdsbmsg.
dwChars = FormatMessage( FORMAT_MESSAGE_FROM_HMODULE |
FORMAT_MESSAGE_IGNORE_INSERTS,
hInst,
dwErr,
0,
wszMsgBuff,
512,
NULL );
// Free the library.
FreeLibrary( hInst );
}
// Display the error message, or generic text if not found.
printf("Error value: %d Message: %ws\n",
dwErr,
dwChars ? wszMsgBuff : L"Error message not found." );
}