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
(Tcl) SSH Public Key AuthenticationDemonstrates how to authenticate with an SSH server using public key authentication.
load ./chilkat.dll # This example assumes the Chilkat API to have been previously unlocked. # See Global Unlock Sample for sample code. set ssh [new_CkSsh] # Set some timeouts, in milliseconds: CkSsh_put_ConnectTimeoutMs $ssh 5000 CkSsh_put_IdleTimeoutMs $ssh 15000 # Connect to the SSH server. # The standard SSH port = 22 # The hostname may be a hostname or IP address. set hostname "sftp.example.com" set port 22 set success [CkSsh_Connect $ssh $hostname $port] if {$success != 1} then { puts [CkSsh_lastErrorText $ssh] delete_CkSsh $ssh exit } set key [new_CkSshKey] # Read the PEM file into a string variable: # (This does not load the PEM file into the key. The LoadText # method is a convenience method for loading the full contents of ANY text # file into a string variable.) set privKey [CkSshKey_loadText $key "myPrivateKey.pem"] if {[CkSshKey_get_LastMethodSuccess $key] != 1} then { puts [CkSshKey_lastErrorText $key] delete_CkSsh $ssh delete_CkSshKey $key exit } # Load a private key from a PEM string: # (Private keys may be loaded from OpenSSH and Putty formats. # Both encrypted and unencrypted private key file formats # are supported. This example loads an unencrypted private # key in OpenSSH format. PuTTY keys typically use the .ppk # file extension, while OpenSSH keys use the PEM format. # (For PuTTY keys, call FromPuttyPrivateKey instead.) set success [CkSshKey_FromOpenSshPrivateKey $key $privKey] if {$success != 1} then { puts [CkSshKey_lastErrorText $key] delete_CkSsh $ssh delete_CkSshKey $key exit } # Authenticate with the SSH server using the login and # private key. (The corresponding public key should've # been installed on the SSH server beforehand.) set success [CkSsh_AuthenticatePk $ssh "myLogin" $key] if {$success != 1} then { puts [CkSsh_lastErrorText $ssh] delete_CkSsh $ssh delete_CkSshKey $key exit } puts [CkSsh_lastErrorText $ssh] puts "Public-Key Authentication Successful!" delete_CkSsh $ssh delete_CkSshKey $key |
© 2000-2025 Chilkat Software, Inc. All Rights Reserved.