Sample code for 30+ languages & platforms
Delphi DLL

Load Certificate (.cer) and Private Key (.pvk) generated from makecert

See more Certificates Examples

Demonstrates how to load a certificate (.cer) and private key (.pvk) from the files produced by makecert, such as in the following command:
makecert -sv mycertificate.pvk -n "CN=My Simple Certificate" mycertificate.cer -sky Exchange

Chilkat Delphi DLL Downloads

Delphi DLL
uses
    Winapi.Windows, Winapi.Messages, System.SysUtils, System.Variants, System.Classes, Vcl.Graphics,
    Vcl.Controls, Vcl.Forms, Vcl.Dialogs, Vcl.StdCtrls, PrivateKey, Pdf, Cert;

...

procedure TForm1.Button1Click(Sender: TObject);
var
success: Boolean;
cert: HCkCert;
privKey: HCkPrivateKey;
pdf: HCkPdf;

begin
success := False;

// First load the .cer file.
// The certificate file (.cer) contains only the certificate (does not include the private key)
cert := CkCert_Create();
success := CkCert_LoadFromFile(cert,'qa_data/certs_and_keys/makecert/mycertificate.cer');
if (success = False) then
  begin
    Memo1.Lines.Add(CkCert__lastErrorText(cert));
    Exit;
  end;

// Next, load the .pvk file.
// Note: The password "secret" is what you entered when makecert displayed the dialog asking for a password..
privKey := CkPrivateKey_Create();
success := CkPrivateKey_LoadPvkFile(privKey,'qa_data/certs_and_keys/makecert/mycertificate.pvk','secret');
if (success = False) then
  begin
    Memo1.Lines.Add(CkPrivateKey__lastErrorText(privKey));
    Exit;
  end;

// Finally, associate the private key with the certificate.
success := CkCert_SetPrivateKey(cert,privKey);
if (success = False) then
  begin
    Memo1.Lines.Add(CkCert__lastErrorText(cert));
    Exit;
  end;

// At this point, the certificate can be used for signing.  For example..
pdf := CkPdf_Create();

// ....
// ....

success := CkPdf_SetSigningCert(pdf,cert);

// ...
// ....

// Some Chilkat classes also provide a method where the cert and private key can be passed separately.
// For example, if SetSigningCert2 is called, then we don't need to explicitly associate the private key with the cert.
success := CkPdf_SetSigningCert2(pdf,cert,privKey);

// ...
// ....

CkCert_Dispose(cert);
CkPrivateKey_Dispose(privKey);
CkPdf_Dispose(pdf);

end;