Sample code for 30+ languages & platforms
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

Chilkat2-Python
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...