Chilkat HOME Android™ AutoIt C C# C++ Chilkat2-Python CkPython Classic ASP DataFlex Delphi DLL Go Java Node.js Objective-C PHP Extension Perl PowerBuilder PowerShell PureBasic Ruby SQL Server Swift Tcl Unicode C Unicode C++ VB.NET VBScript Visual Basic 6.0 Visual FoxPro Xojo Plugin
(PowerShell) TCP or TLS over Multiple Hop SSH to Remote ServerDemonstrates how to use the Chilkat Socket API to connect to a remote server (using TCP or TLS) tunneled through mulitple-hop SSH. The scheme looks like this: Application => ServerSSH1 => ServerSSH2 => DestinationServer The ConnectThroughSsh and UseSsh methods are added in Chilkat version 9.5.0.55 to accomplish this task.
Add-Type -Path "C:\chilkat\ChilkatDotNet47-9.5.0-x64\ChilkatDotNet47.dll" # This example requires the Chilkat API to have been previously unlocked. # See Global Unlock Sample for sample code. $ssh1 = New-Object Chilkat.Ssh # Connect directly to the 1st SSH server. $success = $ssh1.Connect("serverssh1.com",22) if ($success -ne $true) { $($ssh1.LastErrorText) exit } # Authenticate using login/password: $success = $ssh1.AuthenticatePw("ssh1Login","ssh1Password") if ($success -ne $true) { $($ssh1.LastErrorText) exit } # Connect through the 1st SSH connection to reach a 2nd SSH server. # Note: Any number of SSH connections may be simultaneously tunneled through a single # existing SSH connection. $ssh2 = New-Object Chilkat.Ssh $success = $ssh2.ConnectThroughSsh($ssh1,"serverssh2.com",22) if ($success -ne $true) { $($ssh2.LastErrorText) exit } # Authenticate with ssh2... $success = $ssh2.AuthenticatePw("ssh2Login","ssh2Password") if ($success -ne $true) { $($ssh2.LastErrorText) exit } $socket = New-Object Chilkat.Socket # Tell the socket object to connect to our destination server though the ssh2 tunnel (which itself is routed through ssh1). # The connection looks like this: ApplicationSocket(TLS) => ServerSSH1 => ServerSSH2 => DestinationServer $success = $socket.UseSsh($ssh2) if ($success -ne $true) { $($socket.LastErrorText) exit } # Connect using TLS to www.chilkatsoft.com # We could also tunnel a bare TCP connection by specifying port 80 with useTls = $false. $useTls = $true $maxWaitMillisec = 20000 $success = $socket.Connect("www.chilkatsoft.com",443,$useTls,$maxWaitMillisec) if ($success -ne $true) { $($socket.LastErrorText) exit } # Once the multiple hop SSH tunneled connection is setup, the socket programming # is identical to the normal case where we have a direct connection. # Tell the socket object that all text is to be sent in the utf-8 encoding, # and the text received is assumed to be utf-8. $socket.StringCharset = "utf-8" # Send an HTTP HEAD request: $success = $socket.SendString("HEAD / HTTP/1.1`r`nHost: www.chilkatsoft.com`r`n`r`n") if ($success -ne $true) { $($socket.LastErrorText) exit } # Wait a maximum of 4 seconds while no data is forthcoming: $socket.MaxReadIdleMs = 4000 # Get the 1st response line, which should be "HTTP/1.1 200 OK" $responseStatusLine = $socket.ReceiveToCRLF() if ($socket.LastMethodSuccess -ne $true) { $($socket.LastErrorText) exit } $("StatusLine: " + $responseStatusLine) # Now get the 1st line of the response header: $responseHeaderLine = $socket.ReceiveToCRLF() if ($socket.LastMethodSuccess -ne $true) { $($socket.LastErrorText) exit } $("HeaderLine: " + $responseHeaderLine) # Now read the remainder of the response header by reading until a double CRLF is seen: $remainderOfHeader = $socket.ReceiveUntilMatch("`r`n`r`n") if ($socket.LastMethodSuccess -ne $true) { $($socket.LastErrorText) exit } $("Remainder: " + $remainderOfHeader) # Close the connection with the server. This closes the tunnel through ssh2. # Wait a max of 20 seconds (20000 millsec) $success = $socket.Close(20000) # Close the connection with ssh2. (This closes the the tunnel through ssh1.) # The connection with ssh1 is still alive, and may be used for more connections. $ssh2.Disconnect() $ssh1.Disconnect() |
© 2000-2025 Chilkat Software, Inc. All Rights Reserved.