Delphi ActiveX
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
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;