Delphi DLL
Delphi DLL
Load Certificate from Smart Card by Common Name
See more Certificates Examples
This example requires Chilkat v9.5.0.87 or greater. It uses a Windows-only function named LoadFromSmartcard.This example loads a certificate specified by its subject common name (CN part of the Subject). The LoadFromSmartcard method will examine the connected smart cards and USB tokens and will find and load the certificate having the specified CN.
Chilkat Delphi DLL Downloads
uses
Winapi.Windows, Winapi.Messages, System.SysUtils, System.Variants, System.Classes, Vcl.Graphics,
Vcl.Controls, Vcl.Forms, Vcl.Dialogs, Vcl.StdCtrls, Cert;
...
procedure TForm1.Button1Click(Sender: TObject);
var
success: Boolean;
cert: HCkCert;
cert2: HCkCert;
begin
success := False;
// This example requires the Chilkat API to have been previously unlocked.
// See Global Unlock Sample for sample code.
cert := CkCert_Create();
// If you know the smart card PIN, set it prior to loading from the smartcard/USB token.
CkCert_putSmartCardPin(cert,'12345678');
// To load the certificate specified by CN, pass the string "CN=<subjectCN>". For example:
success := CkCert_LoadFromSmartcard(cert,'CN=Ch application signature (8c9be8e0-5544-4cd0-9062-290fbff353a7)');
if (success = False) then
begin
Memo1.Lines.Add(CkCert__lastErrorText(cert));
Memo1.Lines.Add('Certificate not loaded.');
Exit;
end;
Memo1.Lines.Add('Found: ' + CkCert__subjectDN(cert) + ' serial=' + CkCert__serialNumber(cert));
// Here's another example:
cert2 := CkCert_Create();
success := CkCert_LoadFromSmartcard(cert2,'CN=yubikey rsa 1024 authentication');
if (success = False) then
begin
Memo1.Lines.Add(CkCert__lastErrorText(cert2));
Memo1.Lines.Add('Certificate not loaded.');
Exit;
end;
Memo1.Lines.Add('Found: ' + CkCert__subjectDN(cert2) + ' serial=' + CkCert__serialNumber(cert2));
CkCert_Dispose(cert);
CkCert_Dispose(cert2);
end;