Chilkat2-Python
Chilkat2-Python
SFTP use Cert's Private Key for Authentication (Windows)
See more SFTP Examples
Demonstrates how to use the private key of a pre-installed certificate (on Windows) for SFTP authentication. The certificate's private key must be marked as "exportable" when originally installed.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.
cert = chilkat2.Cert()
# Load the certificate from the Windows certificate store
success = cert.LoadByCommonName("my_cert_common_name")
if (success == False):
print(cert.LastErrorText)
sys.exit()
# Get the private key.
privKey = chilkat2.PrivateKey()
success = cert.GetPrivateKey(privKey)
if (success == False):
print(cert.LastErrorText)
sys.exit()
privKeyPem = privKey.GetPkcs8Pem()
if (privKey.LastMethodSuccess == False):
print(privKey.LastErrorText)
sys.exit()
sshKey = chilkat2.SshKey()
success = sshKey.FromOpenSshPrivateKey(privKeyPem)
if (success == False):
print(sshKey.LastErrorText)
sys.exit()
# Connect to an SSH/SFTP server
sftp = chilkat2.SFtp()
success = sftp.Connect("sftp.example.com",22)
if (success == False):
print(sftp.LastErrorText)
sys.exit()
# Authenticate with the SSH server using a username + private key.
# (The private key serves as the password. The username identifies
# the SSH user account on the server.)
success = sftp.AuthenticatePk("mySshLogin",sshKey)
if (success == False):
print(sftp.LastErrorText)
sys.exit()
print("OK, the connection and authentication with the SSH server is completed.")
# This example is only to show the connection + authentication using a private key associated with a certificate in the Windows certificate store...