Funkcja PathIsDirectory może zostać zablokowana, gdy zostanie wywołana przy użyciu nazwy serwera UNC z ukośnikem odwrotnym

Ten artykuł pomaga rozwiązać problem polegający na PathIsDirectory tym, że funkcja może być zablokowana, gdy jest wywoływana przez aplikacje używające nazwy serwera UNC, która ma końcowy ukośnik odwrotny.

Oryginalna wersja produktu: Zestaw Windows SDK dla Windows 10
Oryginalny numer KB: 4525162

Symptomy

Aplikacje wywołujące funkcję PathIsDirectory mogą blokować wywołanie wątku przez maksymalnie dwie minuty podczas wykonywania wywołania przy użyciu nazwy serwera unc (Universal Naming Convention), która ma końcowy ukośnik odwrotny, na przykład: \\servername\.

Przyczyna

Aplikacja blokująca wątek wywołujący w PathIsDirectory wywołaniu może mieć stos wywołań podobny do następującego:

0:000> kn
# Lokacja wywołania child-SP RetAddr
00 0000006f3b59f108 00007ffc94f48ba3 ntdll! ZwWaitForSingleObject+0x14
01 0000006f3b59f110 00007ffc8eebb303 KERNELBASE! WaitForSingleObjectEx+0x93
02 (funkcja wbudowana) ---------------- WINHTTP! HTTP_USER_REQUEST::_HandleSyncPending+0x2d
03 0000006f3b59f1b0 00007ffc8eec9a85 WINHTTP! HTTP_USER_REQUEST::SendRequest+0x3f3
04 0000006f3b59f2b0 00007ffc8afff4fe WINHTTP! WinHttpSendRequest+0x585
05 0000006f3b59f410 00007ffc8b000135 davclnt! DavDoesServerDoDav+0x4ba
06 0000006f3b59f4f0 00007ffc8affc2fa davclnt! DavShouldStartWebclientService+0x2f9
07 0000006f3b59f570 00007ffc70b8e851 davclnt! NPGetResourceInformation+0x23a
08 0000006f3b59f610 00007ffc70b8c7d5 MPR! CGetResourceInformation::TestProvider+0x21
09 0000006f3b59f650 00007ffc70b8c9fd MPR! CRoutedOperation::GetResult+0x135
0a 0000006f3b59f6d0 00007ffc70b8ca69 MPR! CMprOperation::P erform+0x4d
0b 0000006f3b59f710 00007ffc70b8e9bf MPR! CRoutedOperation::P erform+0x29
0c 0000006f3b59f740 00007ffc956ed27c MPR! WNetGetResourceInformationW+0x4f
0d 0000006f3b59f7d0 00007ff7226f292e SHLWAPI! PathIsDirectoryW+0x60fc

Dzieje się tak, gdy funkcja jest wywoływana w WNetGetResourceInformation celu uzyskania informacji o określonym serwerze. W tym stosie wywołań bibliotekę DLL dostawcy sieci Web DAV (DAVCLNT.DLL) blokuje wątek wywołujący, czekając, aż określony serwer odpowie na żądanie HTTP. Przekroczenie limitu czasu tej operacji może potrwać do dwóch minut. Wątek wywołujący zostanie zablokowany, dopóki serwer nie odpowie na żądanie HTTP lub do momentu przekroenia limitu czasu żądania.

Rozwiązanie

Aplikacje mogą uniknąć tego scenariusza, jeśli usuniesz końcowy ukośnik odwrotny w nazwie UNC przed wywołaniem pathIsDirectory , tak jak: \\servername.

Alternatywnie, aby uniknąć opóźnienia żądania HTTP wysyłanego przez dostawcę sieci Web DAV, wyłącz usługę WebClient lub skonfiguruj usługę tak, aby była uruchamiana automatycznie.