Chilkat2-Python
Chilkat2-Python
SFTP Public-Key Authentication
See more SFTP Examples
Demonstrates how to authenticate with an SSH/SFTP server using publickey authentication.Chilkat Chilkat2-Python Downloads
import sys
import chilkat2
success = False
# This example assumes the Chilkat API to have been previously unlocked.
# See Global Unlock Sample for sample code.
sftp = chilkat2.SFtp()
# Set some timeouts, in milliseconds:
sftp.ConnectTimeoutMs = 5000
sftp.IdleTimeoutMs = 15000
# Connect to the SSH server.
# The standard SSH port = 22
# The hostname may be a hostname or IP address.
hostname = "sftp.example.com"
port = 22
success = sftp.Connect(hostname,port)
if (success != True):
print(sftp.LastErrorText)
sys.exit()
key = chilkat2.SshKey()
# Load a 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.)
privKey = key.LoadText("myPrivateKey.pem")
if (key.LastMethodSuccess != True):
print(key.LastErrorText)
sys.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.
success = key.FromOpenSshPrivateKey(privKey)
if (success != True):
print(key.LastErrorText)
sys.exit()
# Authenticate with the SSH server. Chilkat SFTP supports
# both password-based authenication as well as public-key
# authentication.
success = sftp.AuthenticatePk("myLogin",key)
if (success != True):
print(sftp.LastErrorText)
sys.exit()
print(sftp.LastErrorText)
print("Public-Key Authentication Successful!")