Chilkat HOME .NET Core C# Android™ AutoIt C C# C++ Chilkat2-Python CkPython Classic ASP DataFlex Delphi ActiveX Delphi DLL Go Java Lianja Mono C# Node.js Objective-C PHP ActiveX PHP Extension Perl PowerBuilder PowerShell PureBasic Ruby SQL Server Swift 2 Swift 3,4,5... Tcl Unicode C Unicode C++ VB.NET VBScript Visual Basic 6.0 Visual FoxPro Xojo Plugin
(Visual Basic 6.0) SSH ReceiveUntilMatchNDemonstrates how to call the SSH ChannelReceiveUntilMatchN method.
' This example assumes the Chilkat API to have been previously unlocked. ' See Global Unlock Sample for sample code. Dim ssh As New ChilkatSsh Dim success As Long ' For the sake of the example, pretend the remote shell prompt ' will be any of the following: Dim saPrompts As New CkStringArray success = saPrompts.Append("~$") success = saPrompts.Append("mars#") success = saPrompts.Append("jupiter%") success = saPrompts.Append("chilkat$") success = saPrompts.Append("admin>") Dim cmdOutput As String ' Connect to an SSH server: ' Hostname may be an IP address or hostname: Dim hostname As String hostname = "www.some-ssh-server.com" Dim port As Long port = 22 success = ssh.Connect(hostname,port) If (success <> 1) Then Debug.Print ssh.LastErrorText Exit Sub End If ' Wait a max of 10 seconds when reading responses.. ssh.IdleTimeoutMs = 10000 ' Authenticate using login/password: success = ssh.AuthenticatePw("myLogin","myPassword") If (success <> 1) Then Debug.Print ssh.LastErrorText Exit Sub End If ' Open a session channel. (It is possible to have multiple ' session channels open simultaneously.) Dim channelNum As Long channelNum = ssh.OpenSessionChannel() If (channelNum < 0) Then Debug.Print ssh.LastErrorText Exit Sub End If Dim termType As String termType = "dumb" Dim widthInChars As Long widthInChars = 120 Dim heightInChars As Long heightInChars = 40 ' Use 0 for pixWidth and pixHeight when the dimensions ' are set in number-of-chars. Dim pixWidth As Long pixWidth = 0 Dim pixHeight As Long pixHeight = 0 success = ssh.SendReqPty(channelNum,termType,widthInChars,heightInChars,pixWidth,pixHeight) If (success <> 1) Then Debug.Print ssh.LastErrorText Exit Sub End If ' Start a shell on the channel: success = ssh.SendReqShell(channelNum) If (success <> 1) Then Debug.Print ssh.LastErrorText Exit Sub End If ' Run the 1st command in the remote shell, which will be to ' "cd" to a subdirectory. success = ssh.ChannelSendString(channelNum,"cd workspace" & vbLf,"utf-8") If (success <> 1) Then Debug.Print ssh.LastErrorText Exit Sub End If ' Retrieve the output to the next prompt: Dim caseSensitiveMatch As Long caseSensitiveMatch = 1 success = ssh.ChannelReceiveUntilMatchN(channelNum,saPrompts,"utf-8",caseSensitiveMatch) If (success <> 1) Then Debug.Print ssh.LastErrorText 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, it'll think it's ' already finished... cmdOutput = ssh.GetReceivedText(channelNum,"utf-8") If (ssh.LastMethodSuccess <> 1) Then Debug.Print ssh.LastErrorText Exit Sub End If Debug.Print cmdOutput ' Run the 2nd command in the remote shell, which will be ' to "ls" the directory. success = ssh.ChannelSendString(channelNum,"ls" & vbLf,"utf-8") If (success <> 1) Then Debug.Print ssh.LastErrorText Exit Sub End If ' Retrieve and display the output. success = ssh.ChannelReceiveUntilMatchN(channelNum,saPrompts,"utf-8",caseSensitiveMatch) If (success <> 1) Then Debug.Print ssh.LastErrorText Exit Sub End If cmdOutput = ssh.GetReceivedText(channelNum,"utf-8") If (ssh.LastMethodSuccess <> 1) Then Debug.Print ssh.LastErrorText Exit Sub End If Debug.Print cmdOutput ' Start the final command in the remote shell. This example ' will send a "ls -l" command to retrieve the long format directory listing. success = ssh.ChannelSendString(channelNum,"ls -l" & vbLf,"utf-8") If (success <> 1) Then Debug.Print ssh.LastErrorText Exit Sub End If ' 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 <> 1) Then Debug.Print ssh.LastErrorText Exit Sub End If ' Read whatever output may already be available on the ' SSH connection. ChannelReadAndPoll returns the number of bytes ' that are available in the channel's internal buffer that ' are ready to be "picked up" by calling GetReceivedText ' or GetReceivedData. ' A return value of -1 indicates failure. ' A return value of -2 indicates a failure via timeout. ' The ChannelReadAndPoll method waits ' for data to arrive on the connection usingi the IdleTimeoutMs ' property setting. Once the first data arrives, it continues ' reading but instead uses the pollTimeoutMs passed in the 2nd argument: ' A return value of -2 indicates a timeout where no data is received. Dim pollTimeoutMs As Long pollTimeoutMs = 2000 Dim n As Long n = ssh.ChannelReadAndPoll(channelNum,pollTimeoutMs) If (n < 0) Then Debug.Print ssh.LastErrorText Exit Sub End If ' Close the channel: success = ssh.ChannelSendClose(channelNum) If (success <> 1) Then Debug.Print ssh.LastErrorText Exit Sub End If ' Perhaps we did not receive all of the commands output. ' To make sure, call ChannelReceiveToClose to accumulate any remaining ' output until the server's corresponding "channel close" is received. success = ssh.ChannelReceiveToClose(channelNum) If (success <> 1) Then Debug.Print ssh.LastErrorText Exit Sub End If cmdOutput = ssh.GetReceivedText(channelNum,"utf-8") If (ssh.LastMethodSuccess <> 1) Then Debug.Print ssh.LastErrorText Exit Sub End If Debug.Print cmdOutput ' Disconnect ssh.Disconnect |
© 2000-2024 Chilkat Software, Inc. All Rights Reserved.