Delphi DLL
Delphi DLL
Decrypt a .p7m File (using a PFX)
See more Encryption Examples
_LANGUAGE_ sample code showing how to decrypt a .p7m using a .p12 / .pfx certificate w/ private key.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, Crypt2;
...
procedure TForm1.Button1Click(Sender: TObject);
var
success: Boolean;
crypt: HCkCrypt2;
pfxPath: PWideChar;
pfxPassword: PWideChar;
inPath: PWideChar;
outPath: PWideChar;
begin
success := False;
// This example requires the Chilkat API to have been previously unlocked.
// See Global Unlock Sample for sample code.
crypt := CkCrypt2_Create();
// Use a digital certificate and private key from a PFX file (.pfx or .p12).
pfxPath := 'myCertAndKey.pfx';
pfxPassword := 'test123';
success := CkCrypt2_AddPfxSourceFile(crypt,pfxPath,pfxPassword);
if (success <> True) then
begin
Memo1.Lines.Add(CkCrypt2__lastErrorText(crypt));
Exit;
end;
// Set the outPath to whatever is appropriate.
// If you are decrypting a PDF, your output might be "out.pdf"...
inPath := 'smime.p7m';
outPath := 'original.txt';
// Indicate that we're doing public key decryption (i.e. PKCS7)
CkCrypt2_putCryptAlgorithm(crypt,'pki');
success := CkCrypt2_CkDecryptFile(crypt,inPath,outPath);
if (success = False) then
begin
Memo1.Lines.Add(CkCrypt2__lastErrorText(crypt));
Exit;
end;
Memo1.Lines.Add('Success.');
CkCrypt2_Dispose(crypt);
end;