![]() |
Chilkat • HOME • Android™ • AutoIt • C • C# • C++ • Chilkat2-Python • CkPython • Classic ASP • DataFlex • Delphi DLL • Go • Java • Node.js • Objective-C • PHP Extension • Perl • PowerBuilder • PowerShell • PureBasic • Ruby • SQL Server • Swift • Tcl • Unicode C • Unicode C++ • VB.NET • VBScript • Visual Basic 6.0 • Visual FoxPro • Xojo Plugin
(Delphi DLL) Load Certificate (.cer) and Private Key (.pvk) generated from makecertSee more Certificates ExamplesDemonstrates 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
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 cert: HCkCert; success: Boolean; privKey: HCkPrivateKey; pdf: HCkPdf; begin // 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; |
© 2000-2025 Chilkat Software, Inc. All Rights Reserved.