Sample code for 30+ languages & platforms
Tcl

Generate RSA Key for SFTP

See more SSH Key Examples

Generates an 2048-bit RSA key for SSH/SFTP. Your application will use the generated private key. The public key is to be uploaded to the server and stored in the ".ssh" directory located under the HOME directory of the SSH/SFTP user account.

Chilkat Tcl Downloads

Tcl

load ./chilkat.dll

set success 0

# This example requires the Chilkat API to have been previously unlocked.
# See Global Unlock Sample for sample code.

set key [new_CkSshKey]

set numBits 2048
set exponent 65537
set success [CkSshKey_GenerateRsaKey $key $numBits $exponent]
if {$success != 1} then {
    puts "Bad params passed to RSA key generation method."
    delete_CkSshKey $key
    exit
}

# Note: Generating a public/private key pair is CPU intensive
# and may take a short amount of time (more than few seconds,
# but less than a minute).

# Export the RSA private key to encrypted PuTTY format:
CkSshKey_put_Password $key "secret"
set exportEncrypted 1
set exportedKey [CkSshKey_toPuttyPrivateKey $key $exportEncrypted]
set success [CkSshKey_SaveText $key $exportedKey "qa_output/rsa_privkey_putty_encrypted.ppk"]

# Export the public key to openSSH format..
set exportedKey [CkSshKey_toOpenSshPublicKey $key]
set success [CkSshKey_SaveText $key $exportedKey "qa_output/id_rsa.pub"]

# Sample id_rsa.pub:
# ssh-rsa
# AAAAB3NzaC1yc2EAAAADAQABAAA.....6tK3+vjwX/YC9dIXUz2Z 

puts "Finished.  Upload the id_rsa.pub to your .ssh directory located on the SSH/SFTP server under your user account's HOME directory"
puts "(Your HOME directory is the default directory you are in when you login via an SSH terminal.)"

# After the id_rsa.pub is uploaded to your user account on the SSH/SFTP server, you can authenticate using the private key.
# Your application will load the private key (.ppk) as shown here: Load SSH/SFTP Private Key .ppk
# and then authenticate by calling AuthenticatePk (or AuthenticatePwPk).

delete_CkSshKey $key