Răsfoiți Sursa

Issue 2272 – Workaround for SFTP servers (Cisco) which omit message field from status response

https://winscp.net/tracker/2272

Source commit: 05a580e1b0838268feddb314a93064a6d218bc2c
Martin Prikryl 1 an în urmă
părinte
comite
0890a5d8cd
1 a modificat fișierele cu 4 adăugiri și 4 ștergeri
  1. 4 4
      source/core/SftpFileSystem.cpp

+ 4 - 4
source/core/SftpFileSystem.cpp

@@ -2432,10 +2432,10 @@ unsigned long __fastcall TSFTPFileSystem::GotStatusPacket(
     UnicodeString MessageStr = LoadStr(Message);
     UnicodeString ServerMessage;
     UnicodeString LanguageTag;
-    if ((FVersion >= 3) ||
-        // if version is not decided yet (i.e. this is status response
-        // to the init request), go on, only if there are any more data
-        ((FVersion < 0) && (Packet->RemainingLength > 0)))
+    // Message field is defined since version 3 only.
+    // We also might get the packet even before the version is established.
+    // And Cisco servers respond without message field even in version 3.
+    if (Packet->RemainingLength > 0)
     {
       // message is in UTF only since SFTP specification 01 (specification 00
       // is also version 3)