Swift
Swift
SFTP Public-Key Authentication
See more SFTP Examples
Demonstrates how to authenticate with an SSH/SFTP server using publickey authentication.Chilkat Swift Downloads
func chilkatTest() {
var success: Bool = false
// This example assumes the Chilkat API to have been previously unlocked.
// See Global Unlock Sample for sample code.
let sftp = CkoSFtp()!
// 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.
var hostname: String? = "sftp.example.com"
var port: Int = 22
success = sftp.connect(hostname: hostname, port: port)
if success != true {
print("\(sftp.lastErrorText!)")
return
}
let key = CkoSshKey()!
// 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.)
var privKey: String? = key.loadText(path: "myPrivateKey.pem")
if key.lastMethodSuccess != true {
print("\(key.lastErrorText!)")
return
}
// 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(keyStr: privKey)
if success != true {
print("\(key.lastErrorText!)")
return
}
// Authenticate with the SSH server. Chilkat SFTP supports
// both password-based authenication as well as public-key
// authentication.
success = sftp.authenticatePk(username: "myLogin", privateKey: key)
if success != true {
print("\(sftp.lastErrorText!)")
return
}
print("\(sftp.lastErrorText!)")
print("Public-Key Authentication Successful!")
}