[AccessD] Transferring Files via FTP

David Emerson newsgrps at dalyn.co.nz
Fri Oct 9 03:13:56 CDT 2020


Hi Stuart,

I tried that.  Here is the strExe string:
C:\Windows\system32\cmd.exe /c ping sftp.electricityregistry.co.nz -n 1 -w
60000 > "C:\aaTemp\pingtest.txt"

This causes a request times out error (see my separate email).

Regards

David


-----Original Message-----
From: AccessD <accessd-bounces at databaseadvisors.com> On Behalf Of Stuart
McLachlan
Sent: Friday, 9 October 2020 8:56 pm
To: Access Developers discussion and problem solving
<accessd at databaseadvisors.com>
Subject: Re: [AccessD] Transferring Files via FTP

Yep, you should not have put the protocol in front of the host name

PING sftp.electricityregistry.co.nz
not
PING sftp://sftp.electricityregistry.co.nz

On 9 Oct 2020 at 20:43, David Emerson wrote:

> Solved that one by using the IP address instead of the server name.
> 
> -----Original Message-----
> From: AccessD <accessd-bounces at databaseadvisors.com> On Behalf Of 
> David Emerson Sent: Friday, 9 October 2020 8:34 pm To: 'Access 
> Developers discussion and problem solving'
> <accessd at databaseadvisors.com> Subject: Re: [AccessD] Transferring 
> Files via FTP
> 
> Hi Stuart (and others),
> 
> I am working on your code below.  I am initially checking that I can 
> ping to the server using the InternetOK() function but I am getting an
> error: Ping request could not find host 
> sftp://sftp.electricityregistry.co.nz. Please check the name and try 
> again.
> 
> Here is my modified Code (without error coding):
> 
> Function InternetOK() As Boolean
> 
>     Dim strTemp As String, strExe As String, ff As Long
> 
>     strExe = Environ$("COMSPEC")
>     strExe = Left$(strExe, Len(strExe) - Len(Dir(strExe)))
> 
>     strExe = Environ("COMSPEC") & " /c "
>     strExe = strExe & "ping sftp://sftp.electricityregistry.co.nz -n 1
>     > """
> & TempDir() & "pingtest.txt"""
>     ShellWait strExe, vbHide
> 
>     Debug.Print strExe
>     ff = FreeFile
>     Open TempDir() & "pingtest.txt" For Input As #ff
>     Line Input #ff, strTemp
>     Close #ff
>     If InStr(strTemp, "Ping request could not find host") > 0 Then
>         InternetOK = False
>     Else
>         InternetOK = True
>     End If
> 
> End Function
> 
> I am able to connect using FileZilla.  But this includes a login and 
> password.
> 
> Can anyone suggest what I am doing wrong?
> 
> Regards
> 
> David Emerson
> Dalyn Software Ltd
> Wellington, New Zealand
> 
> 
> 
> -----Original Message-----
> From: AccessD <accessd-bounces at databaseadvisors.com> On Behalf Of 
> Stuart McLachlan Sent: Wednesday, 6 May 2020 11:42 am To: Access 
> Developers discussion and problem solving 
> <accessd at databaseadvisors.com> Subject: Re: [AccessD] Transferring 
> Files via FTP
> 
> Heres' a  modFTP from an old application of mine which uses the built 
> in Windows FTP client and an FTP script generated "on the fly".  It 
> will need PTRSAFE, LONGPTR etc modifications for Officer 64bit.
> 
> (These days, I  SHELL to my own applicationa written in PowerBASIC for 
> all FPT processes)
> 
> 
> Option Explicit
> Option Compare Database
> 
> Private Const STARTF_USESHOWWINDOW& = &H1 Private Const 
> NORMAL_PRIORITY_CLASS = &H20& Private Const INFINITE = -1&
> 
> Public g_strFTPPutList() As String
> 
> Private Type STARTUPINFO
>     cb As Long
>     lpReserved As String
>     lpDesktop As String
>     lpTitle As String
>     dwX As Long
>     dwY As Long
>     dwXSize As Long
>     dwYSize As Long
>     dwXCountChars As Long
>     dwYCountChars As Long
>     dwFillAttribute As Long
>     dwFlags As Long
>     wShowWindow As Integer
>     cbReserved2 As Integer
>     lpReserved2 As Long
>     hStdInput As Long
>     hStdOutput As Long
>     hStdError As Long
> End Type
> 
> Private Type PROCESS_INFORMATION
>     hProcess As Long
>     hThread As Long
>     dwProcessID As Long
>     dwThreadID As Long
> End Type
> 
> Declare Function WaitForSingleObject Lib "kernel32" (ByVal hHandle As 
> Long, ByVal dwMilliseconds As Long) As Long
> 
> Declare Function CreateProcessA Lib "kernel32" (ByVal 
> lpApplicationName As Long, ByVal lpCommandLine As String, ByVal 
> lpProcessAttributes As Long, ByVal lpThreadAttributes As Long, ByVal 
> bInheritHandles As Long, ByVal dwCreationFlags As Long, ByVal 
> lpEnvironment As Long, ByVal lpCurrentDirectory As Long, lpStartupInfo 
> As STARTUPINFO, lpProcessInformation As PROCESS_INFORMATION) As Long
> 
> Declare Function CloseHandle Lib "kernel32" (ByVal hObject As Long) As 
> Long
> 
> Public Sub ShellWait(Pathname As String, Optional WindowStyle As Long) 
> On Error GoTo Err_Handler
> 
>    Dim proc As PROCESS_INFORMATION
>    Dim start As STARTUPINFO
>    Dim ret As Long
> 
>    ' Initialize the STARTUPINFO structure:
>    With start
>       .cb = Len(start)
>       If Not IsMissing(WindowStyle) Then
>          .dwFlags = STARTF_USESHOWWINDOW
>          .wShowWindow = WindowStyle
>       End If
>    End With
>    ' Start the shelled application:
>    ret& = CreateProcessA(0&, Pathname, 0&, 0&, 1&,
>    NORMAL_PRIORITY_CLASS,
> 0&, 0&, start, proc)
>    ' Wait for the shelled application to finish:
>    ret& = WaitForSingleObject(proc.hProcess, INFINITE)
>    ret& = CloseHandle(proc.hProcess)
> 
> Exit_Here:
>    Exit Sub
> Err_Handler:
>    MsgBox Err.Description, vbExclamation, "E R R O R"
>    Resume Exit_Here
> 
> End Sub
> 
> 
> 'Following functions look for Site, Login, PW in table usysWeb 
> Function ListFTPFiles(Directory As String) As Variant Const q As 
> String * 1 = """" Dim sEXE As String Dim strList As String Dim
> strFIles() As String Dim x As Long Dim ff As Long strList = TempDir() 
> & "FTPCmds.tmp" ff = FreeFile Open strList For Output As #ff Print 
> #ff, "open " & DLookup("Site", "usysWEB") Print #ff, DLookup("Login",
> "usysWEB") Print #ff, DLookup("PW", "usysWEB") Print #ff, "cd " & 
> Directory Print #ff, "ls . " & TempDir() & "\" & "webfiles.txt" Print 
> #ff, "bye" Close #ff sEXE = Environ$("COMSPEC") sEXE = Left$(sEXE,
> Len(sEXE) - Len(Dir(sEXE))) sEXE = sEXE & "ftp.exe -s:" & q & strList 
> & q ShellWait sEXE, vbHide Kill strList ff = FreeFile Open TempDir() & 
> "webfiles.txt" For Input As #ff While Not EOF(ff)
>    x = x + 1
>    ReDim Preserve strFIles(x)
>    Line Input #1, strFIles(x)
> Wend
> Close #ff
> 'Kill TempDir() & "webfiles.txt"
> ListFTPFiles = strFIles()
> End Function
> 
> Function FTPPut(Directory As String, Filename As String) As Boolean 
> Const q As String * 1 = """" Dim strExe As String Dim strLocalDir As 
> String Dim strFName As String Dim strList As String Dim ff As Long If
> Dir(Filename) = "" Then
>    MsgBox Filename & " not found!"
>    Exit Function
> End If
> strLocalDir = Left$(Filename, InStrRev(Filename, "\") - 1) If
> Len(strLocalDir) = 2 Then strLocalDir = strLocalDir & "\"
> strFName = Mid$(Filename, InStrRev(Filename, "\") + 1) strList =
> TempDir() & "FTPCmds.tmp" ff = FreeFile Open strList For Output As #ff 
> Print #ff, "open " & DLookup("Site", "usysWEB") Print #ff, 
> DLookup("Login", "usysWEB") Print #ff, DLookup("PW", "usysWEB") Print 
> #ff, "cd " & Directory Print #ff, "lcd " & q & strLocalDir & q Print 
> #ff, "binary" Print #ff, "put " & q & strFName & q Print #ff, "bye"
> Close #ff strExe = Environ$("COMSPEC") strExe = Left$(strExe,
> Len(strExe) - Len(Dir(strExe))) strExe = strExe & "ftp.exe -s:" & q & 
> strList & q ShellWait strExe, vbHide 'vbNormalFocus 'Kill strList End 
> Function
> 
> Function FTPGet(Filename As String, LocalDirectory As String) As 
> Boolean Const q As String * 1 = """" Dim strExe As String Dim 
> strFTPDir As String Dim strFName As String Dim strList As String Dim 
> ff As Long If Dir(LocalDirectory, vbDirectory) = "" Then
>    MsgBox LocalDirectory & " not found"
>    Exit Function
> End If
> strFTPDir = Left$(Filename, InStrRev(Filename, "/")) strFName = 
> Mid$(Filename, InStrRev(Filename, "/") + 1) strList = TempDir() & 
> "FTPCmds.tmp" ff = FreeFile Open strList For Output As #ff Print #ff, 
> "open " & DLookup("Site", "usysWEB") Print #ff, DLookup("Login",
> "usysWEB") Print #ff, DLookup("PW", "usysWEB") Print #ff, "cd " & 
> strFTPDir Print #ff, "lcd " & LocalDirectory Print #ff, "binary" Print 
> #ff, "get " & q & strFName & q Print #ff, "bye" Close #ff strExe =
> Environ$("COMSPEC") strExe = Left$(strExe, Len(strExe) -
> Len(Dir(strExe))) strExe = strExe & "ftp.exe -s:" & q & strList & q 
> ShellWait strExe, vbHide Kill strList End Function
> 
> Function InternetOK() As Boolean
> Dim strTemp As String
> Dim strExe As String
> Dim ff As Long
> strExe = Environ$("COMSPEC")
> strExe = Left$(strExe, Len(strExe) - Len(Dir(strExe)))
> 
> strExe = Environ("COMSPEC") & " /c "
> strExe = strExe & "ping " & DLookup("Site", "usysWEB") & " -n 1 > """
> & TempDir() & "pingtest.txt""" ShellWait strExe, vbHide 'Debug.Print 
> strExe ff = FreeFile Open TempDir() & "pingtest.txt" For Input As #ff 
> Line Input #ff, strTemp Close #ff If InStr(strTemp, "Ping request 
> could not find host") > 0 Then
>    InternetOK = False
> Else
>    InternetOK = True
> End If
> 
> End Function
> 
> Function FTPPutList(FileList() As String) As Boolean 'FileList Array 
> is 0 based Row(0) is blank. ' Subsequent rows formatted as:
> RemoteDir[Tab]LocalDir[Tab]Filename[Tab] Const q As String * 1 = """"
> Dim strExe As String Dim strLocalDir As String Dim strRemoteDir As 
> String Dim strLocalDirStore As String Dim strRemoteDirStore As String 
> Dim strFileName As String Dim strList As String Dim strCmds As String 
> Dim ff As Long Dim x As Long Dim strPut() As String strCmds =
> TempDir() & "FTPCmds.tmp" ff = FreeFile Open strCmds For Output As #ff 
> Print #ff, "open " & DLookup("Site", "usysWEB") Print #ff, 
> DLookup("Login", "usysWEB") Print #ff, DLookup("PW", "usysWEB") Print 
> #ff, "binary"
> 
> For x = 1 To UBound(FileList())
>     strPut() = Split(FileList(x), Chr$(9))
>     strRemoteDir = strPut(0)
>     strLocalDir = strPut(1)
>     strFileName = strPut(2)
> 
>     If strRemoteDir <> strRemoteDirStore Then
>        Print #ff, "cd " & strRemoteDir
>        strRemoteDirStore = strRemoteDir
>     End If
> 
>     If strLocalDir <> strLocalDirStore Then
>        Print #ff, "lcd " & strLocalDir
>        strLocalDirStore = strLocalDir
>     End If
> 
>     If Dir(strLocalDir & strFileName) = "" Then
>        MsgBox strLocalDir & strFileName & " not found!"
>        Exit Function
>     End If
> 
>     Print #ff, "put " & q & strFileName & q Next Print #ff, "bye"
> Close #ff strExe = Environ$("COMSPEC") strExe = Left$(strExe,
> Len(strExe) - Len(Dir(strExe))) strExe = strExe & "ftp.exe -s:" & q & 
> strList & q ShellWait strExe, vbHide 'vbNormalFocus End Function
> ---------------------- END OF modFTP
> 
> modFTP also uses this
> 
> Private Declare Function GetTempPath Lib "kernel32" Alias 
> "GetTempPathA" _ (ByVal nBufferLength As Long, ByVal lpBuffer As
> String) As Long
> 
> Public Function TempDir() As String
> Dim strPath As String
>  strPath = Space(MAX_PATH)
>  GetTempPath Len(strPath), strPath
>   TempDir = Left(strPath, InStr(1, strPath, vbNullChar) - 1) End
>   Function
> 
> 
> 
> On 6 May 2020 at 11:07, David Emerson wrote:
> 
> > Hi Listers,
> > 
> > 
> > 
> > I hope everyone is keeping safe.
> > 
> > 
> > 
> > Can anyone give me recommendations for code/software so that I can 
> > log into a secure FTP site using a username and password, and upload 
> > and download files via vba?
> > 
> > 
> > 
> > Regards
> > 
> > David Emerson
> > Dalyn Software Ltd
> > Wellington, New Zealand
> 
> --
> AccessD mailing list
> AccessD at databaseadvisors.com
> http://databaseadvisors.com/mailman/listinfo/accessd
> Website: http://www.databaseadvisors.com
> 
> --
> AccessD mailing list
> AccessD at databaseadvisors.com
> http://databaseadvisors.com/mailman/listinfo/accessd
> Website: http://www.databaseadvisors.com
> 


-- 
AccessD mailing list
AccessD at databaseadvisors.com
http://databaseadvisors.com/mailman/listinfo/accessd
Website: http://www.databaseadvisors.com



More information about the AccessD mailing list