One option is to open a plink session in WScript.Shell instead of executing it with a script file using VBA Shell . The plink program runs interactively from the command line, and the WshExec object gives you direct access to the standard input and standard output from the process you are running. This short example demonstrates its interactive use (it logs on to the telhack.com telnet server system and executes the fnord command), and all console output is copied to the nearest window:
Private Sub Fnord() Dim shell As Object Set shell = CreateObject("WScript.Shell") Dim console As Object 'Open plink in interactive mode. Set console = shell.Exec("c:\putty\plink -telnet telehack.com -P 443") 'Wait for a command prompt. WaitForResponseText console, "." 'Send the fnord command to standard input. console.StdIn.Write ("fnord" & vbCr) 'Wait for the server to echo it back. WaitForResponseText console, ".fnord" 'Read the standard output through the next command prompt. WaitForResponseText console, "." 'Exit the telent session. console.StdIn.Write ("exit" & vbCr) End Sub Private Sub WaitForResponseText(console As Object, response As String) Dim out As String 'Make sure there output to read. If console.StdOut.AtEndOfStream Then Exit Sub Do 'Read a line from standard output. out = console.StdOut.ReadLine() 'Not strictly required, but allows killing the process if this doesn't exit. DoEvents 'Send the server output to the immediate window. Debug.Print out 'Check for the response we're waiting for. If InStr(out, response) Then Exit Do End If Loop Until console.StdOut.AtEndOfStream End Sub
In your case, there is not much βinteractionβ with the server you are connecting to, so it can be as simple as sending all your commands directly to StdIn . Given the wide range of protocol support that plink has, I would be surprised if running a script file is significantly different from this:
Public Sub Chgaccper() Dim shell As Object Set shell = CreateObject("WScript.Shell") Dim console As Object 'Open plink in interactive mode. Set console = shell.Exec("c:\putty\plink server Name -l uname -pw Password") 'Send your commands to the standard input. console.StdIn.Write ("cd /root/home/temp" & vbCr) console.StdIn.Write ("chmod 666 *.csv" & vbCr) console.StdIn.Write ("cd /root/home/temp1" & vbCr) console.StdIn.Write ("chmod 666 *.csv" & vbCr) console.StdIn.Write ("exit" & vbCr) End Sub
If this runs too fast, you can always check to make sure you get the appropriate server responses or add a short wait between sending commands to StdIn .
source share