Elia

Add File Name to FTP Debug

1 post in this topic

Hi All,

I need some help, I am writing a script that FTPs some files and then outputs the results, but I am unable to figure out how to output the file name on line 58. Here is the code (modified to exclude personal information):

 

  1. #include <FTPEx.au3>
  2. #include <MsgBoxConstants.au3>
  3. #include <WinAPIFiles.au3>
  4. #include <Inet.au3>
  5. #include <Debug.au3>
  6. #include <File.au3>
  7. #include <Array.au3>
  8. Local $Server = 'ftp.com'
  9. Local $Username = 'user'
  10. Local $Password = 'password'
  11. Local $LocalFolder = 'C:\Folder'
  12. Local $RemoteFolder = '/users/user1'
  13. Local $SMTPServer = "Exchange.domain.com"
  14. Local $FromName = "FTP"
  15. Local $FromAddress = "email@address.com"
  16. Local $ToAddress = " email@address.com "
  17. Local $Subject = "FTP Transfer Failed, please check server"
  18. Local $Subject1 = "FTP Connection Failed, please check server"
  19. Local $Body[2]
  20. $Body[0] = "Line 1"
  21. $Body[1] = "Line 2"
  22. Local $Body1[2]
  23. $Body1[0] = "Line 1"
  24. $Body1[1] = "Line 2"
  25. $LogFolder = "\\COMP\LOGS"
  26.  
  27. _DebugSetup ("Debug", True)
  28.  
  29. FileMove ("\\COMP\Test\*.txt", "\\COMP\FTP")
  30.  
  31. Local $FolderContents = _FileListToArray("\\COMP\FTP")
  32. Local $LogFile = "\FilesToSend_" & @YEAR & @MON & @MDAY & @HOUR & @MIN & @SEC & ".log"
  33. _FileCreate($LogFolder & $LogFile)
  34. _FileWriteFromArray($LogFolder & $LogFile, $FolderContents)
  35.  
  36. If FileExists ( "\\COMP\FTP" ) Then
  37.     Local $Open = _FTP_Open('FTP')
  38.     Local $CallBack = _FTP_SetStatusCallback($Open, 'FTPStatusCallbackHandler')
  39.     Local $Connect = _FTP_Connect($Open, $Server, $Username, $Password, 0, $INTERNET_DEFAULT_FTP_PORT, $INTERNET_SERVICE_FTP, 0, $CallBack)
  40.         If $Connect <> 0 Then
  41.             Local $Transfer = _FTP_DirPutContents($Connect, $LocalFolder, $RemoteFolder, 0)
  42.             _FTP_Close($Connect)
  43.             _FTP_Close($Open)
  44.                 Else
  45.             _INetSmtpMail($SMTPServer, $FromName, $FromAddress, $ToAddress, $Subject1, $Body, "EHLO" & @ComputerName, -1)
  46.         EndIf
  47.             If $Transfer = 1 Then
  48.                 FileMove ( "\\COMP\FTP\*.txt", "\\COMP\Test\SENT")
  49.                 Else
  50.                 _INetSmtpMail($SMTPServer, $FromName, $FromAddress, $ToAddress, $Subject, $Body1, "EHLO" & @ComputerName, -1)
  51.             EndIf
  52. EndIf
  53. Func FTPStatusCallbackHandler($hInternet, $iContext, $iInternetStatus, $pStatusInformation, $iStatusInformationLength)
  54.                     #forceref $hInternet, $iContext
  55.                     If $iInternetStatus = $INTERNET_STATUS_REQUEST_SENT or $iInternetStatus = $INTERNET_STATUS_RESPONSE_RECEIVED Then
  56.                         Local $iBytesRead
  57.                         Local $tStatus = DllStructCreate('dword')
  58.                         _WinAPI_ReadProcessMemory(_WinAPI_GetCurrentProcess(), $pStatusInformation, $tStatus, $iStatusInformationLength, $iBytesRead)
  59.                         _DebugOut(_FTP_DecodeInternetStatus($iInternetStatus) & ' | Size = ' & DllStructGetData($tStatus, 1) & ' Bytes    Bytes read = ' & $iBytesRead)
  60.                     Else
  61.                         _DebugOut(_FTP_DecodeInternetStatus($iInternetStatus))
  62.                     EndIf
  63.                     EndFunc

I would like the output on line 58 to include a file name, at the moment it only displays the size of the file and Bytes read. Here is what is currently outputted:

Handle created
Resolving name ...
Name resolved
Connecting to server ...
Connected to server
Receiving response ...
Response received | Size = 58 Bytes    Bytes read = 4
Sending request ...
Request sent | Size = 13 Bytes    Bytes read = 4
Receiving response ...
Response received | Size = 20 Bytes    Bytes read = 4
Sending request ...
Request sent | Size = 19 Bytes    Bytes read = 4
Receiving response ...
Response received | Size = 20 Bytes    Bytes read = 4
Handle created
Handle created
Handle created
Handle created
Handle created
Closing connection ...
Connection closed
Handle closing ...

Any help would be greatly appreciated! :)

Thanks.

Share this post


Link to post
Share on other sites



Create an account or sign in to comment

You need to be a member in order to leave a comment

Create an account

Sign up for a new account in our community. It's easy!


Register a new account

Sign in

Already have an account? Sign in here.


Sign In Now

  • Similar Content

    • Xandy
      By Xandy
      Screenshot program that can upload/FTP to website/storage with hotkey.
      Features GUI to display programmable keys.

      Set the hotkeys with this function to use, and display hotkeys.
      ; hotkey_set() Parameters: ; ----------------------------------------------------------- ; $aHotkey -                The array hotkeys are stored in. This function sets the values of this array[hotkey_id][$hotkey_data] ; $dHotkey_id -             The enum for this hotkey index ; $sHotkey_description -     The label displayed to the user to represent function of hotkey ; $sHotkey_name -            The hotkey it'self.  Whatever name string you want to give the key ; $dHotkey_key -             The _IsPressed keycode ;    Keycodes AT: https://www.autoitscript.com/autoit3/docs/libfunctions/_IsPressed.htm ; $dHotkey_shift -             Shift flag 0 or 1 Default off ; $dHotkey_ctrl -             Ctrl flag 0 or 1 Default off ; $dHotkey_alt -             Alt flag 0 or 1 Default off Func hotkey_set(ByRef $aHotkey, $dHotkey_id, $sHotkey_description, $sHotkey_name, $dHotkey_key, $dHotkey_shift = 0, $dHotkey_ctrl = 0, $dHotkey_alt = 0)     $aHotkey[$dHotkey_id][$eHotkey_data_key_description] = $sHotkey_description     $aHotkey[$dHotkey_id][$eHotkey_data_key_name] = $sHotkey_name     $aHotkey[$dHotkey_id][$eHotkey_data_key] = $dHotkey_key     $aHotkey[$dHotkey_id][$eHotkey_data_shift] = $dHotkey_shift     $aHotkey[$dHotkey_id][$eHotkey_data_ctrl] = $dHotkey_ctrl     $aHotkey[$dHotkey_id][$eHotkey_data_alt] = $dHotkey_alt EndFunc   ;==>hotkey_set ; You can set your hotkeys here ; Please visit the hotkey_set() function for parameter information hotkey_set($aHotkey, $eHotkey_screenshot_ftp, "Selected Window to FTP", "F12", "7B", 0, 1, 0); F12 hotkey_set($aHotkey, $eHotkey_screenshot_disk, "Selected Window to Disk", "S", "53", 1, 1, 1); S hotkey_set($aHotkey, $eHotkey_clipboard_send, "Send Clipboard keystrokes", "F10", "79", 1, 1, 1); F10  
      Configure settings dialog:

      Screenshot Filename and Screenshot Counter, are used to create simple unique filenames that can cycle. Copy URL to clipboard option. - For linking your screenshots. The screenshot file type is for local copy only. App always uses .JPG for FTP right now, but I could add FTP screenshot file type specification.  
      Any suggestions?  Did I break anything, what did I miss?
      Package uses TTS.au3 by Beege: 
       
      FTP_Screen.zip
      File includes:
         - FTP_Screen.au3
         - FTPScreen.ico
         - TTS.au3 - by Beege
    • drorshem
      By drorshem
      Hi,
      I'm looking to create a script which will download all *.txt files from a remote FTP server.
      Once downloaded, delete all *.txt files.
       
      Can this be achieved using AutoIt ?
    • Xenobiologist
      By Xenobiologist
      Hi folks,
      I'm using the udf #include <FTPEx.au3> to "download" some files from our zOS (MVS) system via autoit FTP with _FTP_FileGet.
      The FileGet works, but the codepage is wrong. Special German chars like öäüß are not transfered correctly.
      Any idea how to set the codepage? Swichting between binary or ascii doesn't solve the problem.
      Using the ftp command in a cmd.exe window it works like this : quote site sbd=(IBM-273,iso8859-1)
      Thanks
      Mega
    • DCCD
      By DCCD
      Hi, how to get full error reporting if FTP failed?
       
      tried  _WinAPI_GetLastErrorMessage() func but That didn't help at all.  the information was returned by _WinAPI_GetLastErrorMessage() can't help me!
       
       
      _FTP_Open, return Success: a handle, Failure: 0 and sets the @error flag to non-zero
      _FTP_Connect,  return Success: an handle to connected session. Failure: 0 and sets the @error flag to non-zero.
      _FTP_DirCreate, return Success: 1. Failure: 0.
      _FTP_FilePut, return Success: 1. Failure: 0 and sets the @error flag to non-zero.
       
      Any help would be much appreciated
       
       
       
       
    • Elia
      By Elia
      Hi All,
      I am trying to write a script that FTPs multiple files to the same destination using the same FTP session. The script takes the source files, places them on the FTP server, the files should be FTP'd and then moved into the SENT folder in the original location.  I seem to have got everything working except when i try to FTP multiple files, if i put a specific file name under $LocalFile & $RemoteFile under FTP_FilePut then the script works, can anyone tell me where I am going wrong please? I've visited other forums and input an array for the $LocalFile which seems to work, as if i put an ArrayDisplay in it does show me all the files in the folder. I have tried to enter a path, "". '' and "*.*" for $RemoteFile but nothing seems to work:
      #include <FTPEx.au3>
      #include <MsgBoxConstants.au3>
      #include <WinAPIFiles.au3>
      #include <Inet.au3>
      #include <Debug.au3>
      #include <File.au3>
      #include <Array.au3>
      Local $Server = 'ftp.com'
      Local $Username = 'user'
      Local $Password = 'password'
      Local $LocalFile = 'C:\FTP\doc.txt'
      Local $RemoteFile = '*.*'
      Local $FilePath = 'C:\FTP'
      FileMove ("\\COMP\Source\*.txt", "\\COMP\FTP")
      If FileExists ( "\\COMP\FTP" ) Then
          Local $FileList = _FileListToArray($FilePath, "*", 1)
          Local $Open = _FTP_Open('FTP Test')
          Local $Connect = _FTP_Connect($Open, $Server, $Username, $Password)
          If $Connect <> 0 Then
              For $i = 1 to $FileList[0] - 1
                  Local $Transfer = _FTP_FilePut($Connect, $FileList[$i], "" ,0 ,0)             <------------- I think the problem is with the $RemoteFile part
              Next
                  _FTP_Close($Connect)
                  _FTP_Close($Open)
              
                  FileMove ( "\\COMP\FTP\*.txt", "\\COMP\Source\SENT")
           EndIf
      EndIf