Chilkat HOME Android™ Classic ASP C C++ C# Mono C# .NET Core C# C# UWP/WinRT DataFlex Delphi ActiveX Delphi DLL Visual FoxPro Java Lianja MFC Objective-C Perl PHP ActiveX PHP Extension PowerBuilder PowerShell PureBasic CkPython Chilkat2-Python Ruby SQL Server Swift 2 Swift 3,4,5... Tcl Unicode C Unicode C++ Visual Basic 6.0 VB.NET VB.NET UWP/WinRT VBScript Xojo Plugin Node.js Excel Go
(Excel) Using sudo in an SSH Shell SessionDemonstrates how to run a command as sudo in a shell session. Note: This example requires Chilkat v9.5.0.65 or greater.
' This example assumes Chilkat SSH/SFTP to have been previously unlocked. ' See Unlock SSH for sample code. Dim ssh As Chilkat.Ssh Set ssh = Chilkat.NewSsh port = 22 success = ssh.Connect("the-ssh-server.com",port) If (success <> True) Then Debug.Print ssh.LastErrorText Exit Sub End If ' Authenticate using login/password: success = ssh.AuthenticatePw("theSshLogin","theSshPassword") If (success <> True) Then Debug.Print ssh.LastErrorText Exit Sub End If ' Start a shell session. ' (The QuickShell method was added in Chilkat v9.5.0.65) channelNum = ssh.QuickShell() If (channelNum < 0) Then Debug.Print ssh.LastErrorText Exit Sub End If ' Construct a StringBuilder with our command ("ls") run with "sudo" ' Note: The line-endings are potentially important. Some SSH servers may ' require either LF or CRLF line endings. (Unix/Linux/OSX servers typically ' use bare-LF line endings. Windows servers likely use CRLF line endings.) ' Using "sudo -S" causes the sudo prompt to be written to stderr, ' and the password is read from stdin (i.e. from the echo command ouput). ' The sudo commands -p option allows us to set the prompt, and we can set it to ' the empty string, thus eliminating the prompt from the stderr completely. ' This allows us to run the command as root (super-user) with no prompt. Dim sbCommands As Chilkat.StringBuilder Set sbCommands = Chilkat.NewStringBuilder Dim success As Boolean success = sbCommands.Append("echo ""theSshPassword"" | sudo -S -p """" ls" & vbLf) ' Add another command to echo a marker string that ' we'll use in ChannelReceiveUntilMatch below. ' The use of single quotes around 'IS' is a trick so that the output ' of the command is "THIS IS THE END OF THE SCRIPT", but the terminal echo ' includes the single quotes. This allows us to read until we see the actual ' output of the last command. success = sbCommands.Append("echo THIS 'IS' THE END OF THE SCRIPT" & vbLf) ' Send the commands.. success = ssh.ChannelSendString(channelNum,sbCommands.GetAsString(),"ansi") If (success <> True) Then Debug.Print ssh.LastErrorText Exit Sub End If ' Send an EOF to indicate no more commands will be sent. ' For brevity, we're not checking the return values of each method call. ' Your code should check the success/failure of each call. success = ssh.ChannelSendEof(channelNum) ' Receive output up to our marker. success = ssh.ChannelReceiveUntilMatch(channelNum,"THIS IS THE END OF THE SCRIPT","ansi",True) ' Close the channel. ' It is important to close the channel only after receiving the desired output. success = ssh.ChannelSendClose(channelNum) ' Get any remaining output.. success = ssh.ChannelReceiveToClose(channelNum) ' Get the complete output for all the commands in the session. Debug.Print "--- output ----" Debug.Print ssh.GetReceivedText(channelNum,"ansi") |
© 2000-2022 Chilkat Software, Inc. All Rights Reserved.