PowerShell Examples

ChilkatHOMEAndroid™ASPVisual BasicVB.NETC#iOS (IPhone)Objective-CC++CMFCDelphiFoxProJavaPerl
PHP ExtensionPHP ActiveXPythonPowerShellRubySQL ServerVBScript

PowerShell Examples

Bounced Email
Digital Certificates
Digital Signatures
DSA
Email Object
Encryption
FTP
HTML Conversion
HTTP
IMAP
MHT / HTML Email
POP3
RSA
MIME
SMTP
Socket
SOCKS Proxy
Spider
SSH Key
SSH
SFTP
Tar
Upload
XML
XMP
Zip


More Examples...
Amazon S3
NTLM
RSS
Atom
PPMD
Deflate
Bzip2
LZW
Diffie-Hellman
Bz2
Character Encoding
CSV

 

 

 

 

 

 

 

 

(PowerShell) SSH Exec (Execute Command Line)

Shows how to execute a command on an SSH server and retrieve the command output.

Download: Chilkat .NET Assemblies

[Reflection.Assembly]::LoadFile("C:\myAssemblies\ChilkatDotNet2.dll")

#  Important: It is helpful to send the contents of the
#  ssh.LastErrorText property when requesting support.

$ssh = New-Object Chilkat.Ssh

#  Any string automatically begins a fully-functional 30-day trial.
$success = $ssh.UnlockComponent("Anything for 30-day trial")
if ($success -ne $true) {
    $($ssh.LastErrorText)
    exit
}

#  Connect to an SSH server:

#  Hostname may be an IP address or hostname:
$hostname = "192.168.1.108"
$port = 22

$success = $ssh.Connect($hostname,$port)
if ($success -ne $true) {
    $($ssh.LastErrorText)
    exit
}

#  Wait a max of 5 seconds when reading responses..
$ssh.IdleTimeoutMs = 5000

#  Authenticate using login/password:
$success = $ssh.AuthenticatePw("myLogin","myPassword")
if ($success -ne $true) {
    $($ssh.LastErrorText)
    exit
}

#  Open a session channel.  (It is possible to have multiple
#  session channels open simultaneously.)

$channelNum = $ssh.OpenSessionChannel()
if ($channelNum -lt 0) {
    $($ssh.LastErrorText)
    exit
}

#  The SendReqExec method starts a command on the remote
#  server.   The syntax of the command string depends on the
#  default shell used on the remote server to run the command.
#  On Windows systems it is CMD.EXE.  On UNIX/Linux
#  systems the user's default shell is typically defined in /etc/password.

#  Here are some examples of command lines for <b>Windows SSH servers</b>:

#  Get a directory listing:
$cmd1 = "dir"

#  Do a nameserver lookup:
$cmd2 = "nslookup chilkatsoft.com"

#  List a specific directory.  Given that the shell is CMD.EXE, backslashes must
#  be used:
$cmd3 = "dir \\temp"

#  Execute a sequence of commands.  The syntax for CMD.EXE may be found
#  here: http://technet.microsoft.com/en-us/library/bb490880.aspx.  Notice how the commands
#  are separated by "&&" and the entire command must be enclosed in quotes:
$cmd4 = "\"cd \\temp&&dir\""

#  Here are two examples of command lines for <b>Linux/UNIX SSH servers</b>:

#  Get a directory listing:
$cmd5 = "ls -l /tmp"

#  Run a series of commands (syntax may depend on your default shell):
$cmd6 = "cd /etc; ls -la"

#  Request a directory listing on the remote server:
#  If your server is Windows, change the string from "ls" to "dir"
$success = $ssh.SendReqExec($channelNum,"ls")
if ($success -ne $true) {
    $($ssh.LastErrorText)
    exit
}

#  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.

$pollTimeoutMs = 2000
$n = $ssh.ChannelReadAndPoll($channelNum,$pollTimeoutMs)
if ($n -lt 0) {
    $($ssh.LastErrorText)
    exit
}

#  Close the channel:
$success = $ssh.ChannelSendClose($channelNum)
if ($success -ne $true) {
    $($ssh.LastErrorText)
    exit
}

#  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 -ne $true) {
    $($ssh.LastErrorText)
    exit
}

#  Let's pickup the accumulated output of the command:

$cmdOutput = $ssh.GetReceivedText($channelNum,"ansi")
if ($cmdOutput -eq $null ) {
    $($ssh.LastErrorText)
    exit
}

#  Display the remote shell's command output:
$($cmdOutput)

#  Disconnect
$ssh.Disconnect()

© 2000-2011 Chilkat Software, Inc. All Rights Reserved.