Uwaga
Dostęp do tej strony wymaga autoryzacji. Może spróbować zalogować się lub zmienić katalogi.
Dostęp do tej strony wymaga autoryzacji. Możesz spróbować zmienić katalogi.
Funkcje sieci WNet zwracają kody błędów pod kątem zgodności z grupami roboczymi systemu Windows. Każda funkcja WNet ustawia również wartość kodu błędu zwróconą przez GetLastError.
Gdy jedna z funkcji sieci WNet zwraca ERROR_EXTENDED_ERROR, aplikacja może wywołać funkcję WNetGetLastError w celu pobrania dodatkowych informacji o błędzie. Te informacje są zwykle specyficzne dla dostawcy sieci.
W poniższym przykładzie przedstawiono funkcję obsługi błędów zdefiniowaną przez aplikację (NetErrorHandler). Funkcja przyjmuje trzy argumenty: uchwyt okna, kod błędu zwrócony przez jedną z funkcji sieci WNet oraz nazwę funkcji, która wygenerowała błąd. Jeśli kod błędu jest ERROR_EXTENDED_ERROR, program NetErrorHandler wywołuje WNetGetLastError, aby uzyskać rozszerzone informacje o błędzie i wyświetli informacje. Przykład wywołuje funkcję MessageBox w celu przetwarzania komunikatów.
#include <windows.h>
#include <stdio.h>
#pragma comment(lib, "mpr.lib")
#pragma comment(lib, "user32.lib")
BOOL WINAPI NetErrorHandler(HWND hwnd,
DWORD dwErrorCode,
LPSTR lpszFunction)
{
DWORD dwWNetResult, dwLastError;
CHAR szError[256];
CHAR szCaption[256];
CHAR szDescription[256];
CHAR szProvider[256];
// The following code performs standard error-handling.
if (dwErrorCode != ERROR_EXTENDED_ERROR)
{
sprintf_s((LPSTR) szError, sizeof(szError), "%s failed; \nResult is %ld",
lpszFunction, dwErrorCode);
sprintf_s((LPSTR) szCaption, sizeof(szCaption), "%s error", lpszFunction);
MessageBox(hwnd, (LPSTR) szError, (LPSTR) szCaption, MB_OK);
return TRUE;
}
// The following code performs error-handling when the
// ERROR_EXTENDED_ERROR return value indicates that the
// WNetGetLastError function can retrieve additional information.
else
{
dwWNetResult = WNetGetLastError(&dwLastError, // error code
(LPSTR) szDescription, // buffer for error description
sizeof(szDescription), // size of error buffer
(LPSTR) szProvider, // buffer for provider name
sizeof(szProvider)); // size of name buffer
//
// Process errors.
//
if(dwWNetResult != NO_ERROR) {
sprintf_s((LPSTR) szError, sizeof(szError),
"WNetGetLastError failed; error %ld", dwWNetResult);
MessageBox(hwnd, (LPSTR) szError, "WNetGetLastError", MB_OK);
return FALSE;
}
//
// Otherwise, print the additional error information.
//
sprintf_s((LPSTR) szError, sizeof(szError),
"%s failed with code %ld;\n%s",
(LPSTR) szProvider, dwLastError, (LPSTR) szDescription);
sprintf_s((LPSTR) szCaption, sizeof(szCaption), "%s error", lpszFunction);
MessageBox(hwnd, (LPSTR) szError, (LPSTR) szCaption, MB_OK);
return TRUE;
}
}