Sample code for 30+ languages & platforms
Perl

SFTP Public-Key Authentication

See more SFTP Examples

Demonstrates how to authenticate with an SSH/SFTP server using publickey authentication.

Chilkat Perl Downloads

Perl
use chilkat();

$success = 0;

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

$sftp = chilkat::CkSFtp->new();

# Set some timeouts, in milliseconds:
$sftp->put_ConnectTimeoutMs(5000);
$sftp->put_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 != 1) {
    print $sftp->lastErrorText() . "\r\n";
    exit;
}

$key = chilkat::CkSshKey->new();

# 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->get_LastMethodSuccess() != 1) {
    print $key->lastErrorText() . "\r\n";
    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 != 1) {
    print $key->lastErrorText() . "\r\n";
    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 != 1) {
    print $sftp->lastErrorText() . "\r\n";
    exit;
}

print $sftp->lastErrorText() . "\r\n";
print "Public-Key Authentication Successful!" . "\r\n";