Chilkat HOME ASP Visual Basic VB.NET C# Visual C++ C MFC Delphi FoxPro Java Perl PHP Python Ruby SQL Server VBScript
SSH -- Running Commands that Prompt for Additional Input, such as "su"Demonstrates how to run a shell command via SSH where the shell command prompts for additional input from the client. This example demonstrates "su".
' Important: It is helpful to send the contents of the ' ssh.LastErrorText property when requesting support. Dim ssh As New Chilkat.Ssh() ' Any string automatically begins a fully-functional 30-day trial. Dim success As Boolean success = ssh.UnlockComponent("30-day trial") If (success <> true) Then MsgBox(ssh.LastErrorText) Exit Sub End If Dim hostname As String Dim port As Long ' Hostname may be an IP address or hostname: hostname = "192.168.1.117" port = 22 ' Keep a session log, which is available via the SessionLog ' property: ssh.KeepSessionLog = true success = ssh.Connect(hostname,port) If (success <> true) Then TextBox1.Text = TextBox1.Text & ssh.LastErrorText & vbCrLf TextBox1.Text = TextBox1.Text & ssh.SessionLog & vbCrLf Exit Sub End If ' When reading, if no additional data arrives for more than ' 5 seconds, then abort: ssh.IdleTimeoutMs = 5000 ' SSH Server Authentication ' If there is no login/password required, you must still call ' AuthenticatePw and use any values for login/password. success = ssh.AuthenticatePw("chilkat","myPassword") If (success <> true) Then TextBox1.Text = TextBox1.Text & ssh.LastErrorText & vbCrLf TextBox1.Text = TextBox1.Text & ssh.SessionLog & vbCrLf Exit Sub End If ' Open a session channel. Dim channelNum As Long channelNum = ssh.OpenSessionChannel() If (channelNum < 0) Then TextBox1.Text = TextBox1.Text & ssh.LastErrorText & vbCrLf TextBox1.Text = TextBox1.Text & ssh.SessionLog & vbCrLf Exit Sub End If ' Request a pseudo-terminal Dim termType As String termType = "dumb" Dim widthInChars As Long widthInChars = 120 Dim heightInChars As Long heightInChars = 40 Dim pixWidth As Long pixWidth = 0 Dim pixHeight As Long pixHeight = 0 success = ssh.SendReqPty(channelNum,termType,widthInChars,heightInChars,pixWidth,pixHeight) If (success <> true) Then TextBox1.Text = TextBox1.Text & ssh.LastErrorText & vbCrLf TextBox1.Text = TextBox1.Text & ssh.SessionLog & vbCrLf Exit Sub End If ' Start a shell on the channel: success = ssh.SendReqShell(channelNum) If (success <> true) Then TextBox1.Text = TextBox1.Text & ssh.LastErrorText & vbCrLf TextBox1.Text = TextBox1.Text & ssh.SessionLog & vbCrLf Exit Sub End If ' Send the su command. ' (The SSH server I'm using for testing is a Linux Ubuntu ' system running OpenSSH. It is important in this case to send a bare-LF ' and not a CRLF.) Dim cmd As String cmd = "su" & vbLf success = ssh.ChannelSendString(channelNum,cmd,"ansi") If (success <> true) Then TextBox1.Text = TextBox1.Text & ssh.LastErrorText & vbCrLf TextBox1.Text = TextBox1.Text & ssh.SessionLog & vbCrLf Exit Sub End If ' Read until we get the prompt for the password: success = ssh.ChannelReceiveUntilMatch(channelNum,"Password:","ansi",true) If (success <> true) Then TextBox1.Text = TextBox1.Text & ssh.LastErrorText & vbCrLf TextBox1.Text = TextBox1.Text & ssh.SessionLog & vbCrLf Exit Sub End If ' Display what we've received so far: TextBox1.Text = TextBox1.Text & ssh.GetReceivedText(channelNum,"ansi") & vbCrLf ' Send the password. ' Again, make sure it uses a bare-LF and not a CRLF. Dim password As String password = "myPassword" & vbLf success = ssh.ChannelSendString(channelNum,password,"ansi") If (success <> true) Then TextBox1.Text = TextBox1.Text & ssh.LastErrorText & vbCrLf TextBox1.Text = TextBox1.Text & ssh.SessionLog & vbCrLf Exit Sub End If ' Read the response until we get the shell prompt (assuming it's successful) ' In my case, the shell prompt is: "root@ubuntu:/home/chilkat# " ' It will be different in your case. success = ssh.ChannelReceiveUntilMatch(channelNum,"root@ubuntu:/home/chilkat#","ansi",true) If (success <> true) Then ' Check the last-error information and the session log... TextBox1.Text = TextBox1.Text & ssh.LastErrorText & vbCrLf TextBox1.Text = TextBox1.Text & ssh.SessionLog & vbCrLf ' Check to see what was received. TextBox1.Text = TextBox1.Text & ssh.GetReceivedText(channelNum,"ansi") & vbCrLf Exit Sub End If ' Display what we've received so far. This clears ' the internal receive buffer, which is important. ' After we send the command, we'll be reading until ' the next command prompt. If the command prompt ' is already in the internal receive buffer, we'll think we're ' already finished... TextBox1.Text = TextBox1.Text & ssh.GetReceivedText(channelNum,"ansi") & vbCrLf ' Send a command. In this case, we are sending the "ls" command: cmd = "ls" & vbLf success = ssh.ChannelSendString(channelNum,cmd,"ansi") If (success <> true) Then TextBox1.Text = TextBox1.Text & ssh.LastErrorText & vbCrLf TextBox1.Text = TextBox1.Text & ssh.SessionLog & vbCrLf Exit Sub End If ' Read until the next command prompt: success = ssh.ChannelReceiveUntilMatch(channelNum,"root@ubuntu:/home/chilkat#","ansi",true) If (success <> true) Then ' Check the last-error information and the session log... TextBox1.Text = TextBox1.Text & ssh.LastErrorText & vbCrLf TextBox1.Text = TextBox1.Text & ssh.SessionLog & vbCrLf ' Check to see what was received. TextBox1.Text = TextBox1.Text & ssh.GetReceivedText(channelNum,"ansi") & vbCrLf Exit Sub End If ' Display the command output: TextBox1.Text = TextBox1.Text & ssh.GetReceivedText(channelNum,"ansi") & vbCrLf ' You may continue sending additional commands. ' The technique is: send the command, read until the next command prompt, ' and then fetch/clear the internal receive buffer. ' We're done, so shut it down.. ' Send an EOF. This tells the server that no more data will ' be sent on this channel. The channel remains open, and ' the SSH client may still receive output on this channel. success = ssh.ChannelSendEof(channelNum) If (success <> true) Then TextBox1.Text = TextBox1.Text & ssh.LastErrorText & vbCrLf TextBox1.Text = TextBox1.Text & ssh.SessionLog & vbCrLf Exit Sub End If ' Close the channel: success = ssh.ChannelSendClose(channelNum) If (success <> true) Then TextBox1.Text = TextBox1.Text & ssh.LastErrorText & vbCrLf TextBox1.Text = TextBox1.Text & ssh.SessionLog & vbCrLf Exit Sub End If ' Disconnect ssh.Disconnect() |
Need a specific example? Send a request to support@chilkatsoft.com
© 2000-2010 Chilkat Software, Inc. All Rights Reserved.