Sample code for 30+ languages & platforms
Delphi ActiveX

SFTP use Cert's Private Key from PFX (.pfx/.p12)

See more SFTP Examples

Demonstrates how to use the private key associated with a certificate from a .pfx/.p12 file.

Chilkat Delphi ActiveX Downloads

Delphi ActiveX
uses
    Winapi.Windows, Winapi.Messages, System.SysUtils, System.Variants, System.Classes, Vcl.Graphics,
    Vcl.Controls, Vcl.Forms, Vcl.Dialogs, Vcl.StdCtrls, Chilkat_TLB;

...

procedure TForm1.Button1Click(Sender: TObject);
var
success: Integer;
cert: TChilkatCert;
pfxFilepath: WideString;
pfxPassword: WideString;
privKey: TPrivateKey;
privKeyPem: WideString;
sshKey: TChilkatSshKey;
sftp: TChilkatSFtp;

begin
success := 0;

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

cert := TChilkatCert.Create(Self);

pfxFilepath := 'qa_data/pfx/my.pfx';
pfxPassword := 'secret';

// A PFX typically contains certificates in the chain of authentication.
// The Chilkat cert object will choose the certificate w/
// private key farthest from the root authority cert.
// To access all the certificates in a PFX, use the 
// Chilkat certificate store object instead.
success := cert.LoadPfxFile(pfxFilepath,pfxPassword);
if (success = 0) then
  begin
    Memo1.Lines.Add(cert.LastErrorText);
    Exit;
  end;

// Get the private key.  
privKey := TPrivateKey.Create(Self);
success := cert.GetPrivateKey(privKey.ControlInterface);
if (success = 0) then
  begin
    Memo1.Lines.Add(cert.LastErrorText);
    Exit;
  end;

privKeyPem := privKey.GetPkcs8Pem();
if (privKey.LastMethodSuccess = 0) then
  begin
    Memo1.Lines.Add(privKey.LastErrorText);
    Exit;
  end;

sshKey := TChilkatSshKey.Create(Self);
success := sshKey.FromOpenSshPrivateKey(privKeyPem);
if (success = 0) then
  begin
    Memo1.Lines.Add(sshKey.LastErrorText);
    Exit;
  end;

// Connect to an SSH/SFTP server
sftp := TChilkatSFtp.Create(Self);
success := sftp.Connect('sftp.example.com',22);
if (success = 0) then
  begin
    Memo1.Lines.Add(sftp.LastErrorText);
    Exit;
  end;

// 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.ControlInterface);
if (success = 0) then
  begin
    Memo1.Lines.Add(sftp.LastErrorText);
    Exit;
  end;

Memo1.Lines.Add('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...
end;