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) Send Signed Email using PFX FileDemonstrates how to send a signed email using a digital certificate w/ private key stored in a PFX file.
uses Winapi.Windows, Winapi.Messages, System.SysUtils, System.Variants, System.Classes, Vcl.Graphics, Vcl.Controls, Vcl.Forms, Vcl.Dialogs, Vcl.StdCtrls, MailMan, Email; ... procedure TForm1.Button1Click(Sender: TObject); var mailman: HCkMailMan; email: HCkEmail; success: Boolean; begin // This example requires the Chilkat API to have been previously unlocked. // See Global Unlock Sample for sample code. // The mailman object is used for sending and receiving email. mailman := CkMailMan_Create(); // Set the SMTP server. CkMailMan_putSmtpHost(mailman,'smtp.mymailserver.com'); // Create a new email object email := CkEmail_Create(); CkEmail_putSubject(email,'This email is signed'); CkEmail_putBody(email,'This is a digitally signed mail'); CkEmail_putFrom(email,'Chilkat Admin <admin@chilkatsoft.com>'); success := CkEmail_AddTo(email,'Chilkat Support','support@chilkatsoft.com'); // Indicate that the email should be sent signed. CkEmail_putSendSigned(email,True); // Tell the mailman to use a PFX file as a source for locating // the certificate and private key required for signing. // The certificate chosen for signing will be the one that // matches the sender's email address, which also has // a private key. All intermediate certs in the chain of // authentication, up to and including the root, will // be included in the signature. success := CkMailMan_AddPfxSourceFile(mailman,'/pfx_files/chilkatsoft_secret.pfx','secret'); if (success <> True) then begin Memo1.Lines.Add(CkMailMan__lastErrorText(mailman)); Exit; end; // Signed email can be sent in two different ways. // In a multipart/signed email, the signature is attached as a separate MIME part. // In an opaque email (signedData) the content of the email is encapsulated within the signature // and the email is sent as "application/pkcs7-mime". // Either should be fine, but some receiving systems might require one or the other.. CkMailMan_putOpaqueSigning(mailman,False); // Send a signed email. success := CkMailMan_SendEmail(mailman,email); if (success <> True) then begin Memo1.Lines.Add(CkMailMan__lastErrorText(mailman)); end else begin // The LastErrorText property provides information // even when successful. Memo1.Lines.Add(CkMailMan__lastErrorText(mailman)); Memo1.Lines.Add('Mail Sent!'); end; CkMailMan_Dispose(mailman); CkEmail_Dispose(email); end; |
© 2000-2025 Chilkat Software, Inc. All Rights Reserved.