浏览代码

Invalid FTP response was incorrectly logged when closing transfer connection (caused by cee1be5d)

(cherry picked from commit b62d433c40fb35bcb41f607db098d997de302b56)

Source commit: cac10ad16cc4930bb1acd13052445a8423a5b7b4
Martin Prikryl 3 年之前
父节点
当前提交
e25a70c001
共有 2 个文件被更改,包括 26 次插入3 次删除
  1. 25 3
      source/filezilla/FtpControlSocket.cpp
  2. 1 0
      source/filezilla/FtpControlSocket.h

+ 25 - 3
source/filezilla/FtpControlSocket.cpp

@@ -1529,12 +1529,16 @@ BOOL CFtpControlSocket::Send(CString str)
   return TRUE;
 }
 
-int CFtpControlSocket::GetReplyCode()
+int CFtpControlSocket::TryGetReplyCode()
 {
   if (m_RecvBuffer.empty())
     return 0;
   CStringA str = m_RecvBuffer.front();
-  if ((str == "") || (str[0] < '1') || (str[0] > '9'))
+  if (str == "")
+  {
+    return -1;
+  }
+  else if ((str[0] < '1') || (str[0] > '9'))
   {
     UnicodeString Error = FMTLOAD(FTP_MALFORMED_RESPONSE, (UnicodeString(str)));
     LogMessageRaw(FZ_LOG_WARNING, Error.c_str());
@@ -1546,6 +1550,18 @@ int CFtpControlSocket::GetReplyCode()
   }
 }
 
+int CFtpControlSocket::GetReplyCode()
+{
+  int Result = TryGetReplyCode();
+  if (Result < 0)
+  {
+    UnicodeString Error = FMTLOAD(FTP_MALFORMED_RESPONSE, (UnicodeString()));
+    LogMessageRaw(FZ_LOG_WARNING, Error.c_str());
+    Result = 0;
+  }
+  return Result;
+}
+
 void CFtpControlSocket::DoClose(int nError /*=0*/)
 {
   LogMessage(FZ_LOG_INFO, L"Connection closed");
@@ -2928,7 +2944,13 @@ void CFtpControlSocket::FileTransfer(t_transferfile *transferfile/*=0*/,BOOL bFi
     ///////////
     //Replies//
     ///////////
-    int code = GetReplyCode();
+    int code = TryGetReplyCode();
+    // We do not always expect a response here, particularly when closing transfer connection (FILETRANSFER_WAITFINISH).
+    // The normalization to 0 is probably not needed.
+    if (code < 0)
+    {
+      code = 0;
+    }
     switch(m_Operation.nOpState)
     {
     case FILETRANSFER_PWD:

+ 1 - 0
source/filezilla/FtpControlSocket.h

@@ -119,6 +119,7 @@ protected:
   void ResetTransferSocket(int Error);
 
   void DoClose(int nError = 0);
+  int TryGetReplyCode();
   int GetReplyCode();
   CString GetReply();
   void LogOnToServer(BOOL bSkipReply = FALSE);