エラー コード番号のテキストの検索
ネットワーク関連の関数から返されるエラー コードに関連付けられているエラー テキストを表示することが必要な場合があります。 システムによって提供されるネットワーク管理機能を使用して、このタスクを実行する必要がある場合があります。
これらのメッセージのエラー テキストは、%systemroot%\system32 にある Netmsg.dll という名前のメッセージ テーブル ファイルにあります。 このファイルには、NERR_BASE (2100) ~ MAX_NERR (NERR_BASE+899) の範囲内のエラー メッセージが含まれています。 これらのエラー コードは、SDK ヘッダー ファイル lmerr.h で定義されています。
LoadLibrary 関数と LoadLibraryEx 関数は、Netmsg.dllを読み込むことができます。 FormatMessage 関数は、モジュール ハンドルをNetmsg.dll ファイルに渡して、エラー コードをメッセージ テキストにマップします。
次の例では、システム関連のエラー コードに関連付けられているエラー テキストを表示するだけでなく、ネットワーク管理機能に関連付けられているエラー テキストを表示する方法を示します。 指定されたエラー番号が特定の範囲にある場合は、netmsg.dll メッセージ モジュールが読み込まれ、 FormatMessage 関数を使用して指定したエラー番号を検索するために使用されます。
#include <windows.h>
#include <stdio.h>
#include <lmerr.h>
void
DisplayErrorText(
DWORD dwLastError
);
#define RTN_OK 0
#define RTN_USAGE 1
#define RTN_ERROR 13
int
__cdecl
main(
int argc,
char *argv[]
)
{
if(argc != 2) {
fprintf(stderr,"Usage: %s <error number>\n", argv[0]);
return RTN_USAGE;
}
DisplayErrorText( atoi(argv[1]) );
return RTN_OK;
}
void
DisplayErrorText(
DWORD dwLastError
)
{
HMODULE hModule = NULL; // default to system source
LPSTR MessageBuffer;
DWORD dwBufferLength;
DWORD dwFormatFlags = FORMAT_MESSAGE_ALLOCATE_BUFFER |
FORMAT_MESSAGE_IGNORE_INSERTS |
FORMAT_MESSAGE_FROM_SYSTEM ;
//
// If dwLastError is in the network range,
// load the message source.
//
if(dwLastError >= NERR_BASE && dwLastError <= MAX_NERR) {
hModule = LoadLibraryEx(
TEXT("netmsg.dll"),
NULL,
LOAD_LIBRARY_AS_DATAFILE
);
if(hModule != NULL)
dwFormatFlags |= FORMAT_MESSAGE_FROM_HMODULE;
}
//
// Call FormatMessage() to allow for message
// text to be acquired from the system
// or from the supplied module handle.
//
if(dwBufferLength = FormatMessageA(
dwFormatFlags,
hModule, // module to get message from (NULL == system)
dwLastError,
MAKELANGID(LANG_NEUTRAL, SUBLANG_DEFAULT), // default language
(LPSTR) &MessageBuffer,
0,
NULL
))
{
DWORD dwBytesWritten;
//
// Output message string on stderr.
//
WriteFile(
GetStdHandle(STD_ERROR_HANDLE),
MessageBuffer,
dwBufferLength,
&dwBytesWritten,
NULL
);
//
// Free the buffer allocated by the system.
//
LocalFree(MessageBuffer);
}
//
// If we loaded a message source, unload it.
//
if(hModule != NULL)
FreeLibrary(hModule);
}
このプログラムをコンパイルした後、エラー コード番号を引数として挿入すると、プログラムにテキストが表示されます。 次に例を示します。
C:\> netmsg 2453
Could not find domain controller for this domain