Chilkat HOME ASP Visual Basic VB.NET C# Visual C++ C MFC Delphi FoxPro Java Perl PHP Python Ruby SQL Server VBScript
Send Already-Signed MIME w/ SendMimeDemonstrates how to use SendMime to send an already-signed MIME message.
// Needs #include <CkMailMan.h> // Needs #include <CkEmail.h> // Needs #include <CkCertStore.h> // Needs #include <CkCert.h> CkString strOut; // The mailman object is used for sending and receiving email. CkMailMan mailman; // Any string argument automatically begins the 30-day trial. bool success; success = mailman.UnlockComponent("30-day trial"); if (success != true) { strOut.append("Component unlock failed\r\n"); SetDlgItemText(IDC_EDIT1,strOut.getUnicode()); return; } // Set the SMTP server. mailman.put_SmtpHost("smtp.chilkatsoft.com"); // Create a new email object CkEmail email; email.put_Subject("This email is signed"); email.put_Body("This is a digitally signed mail"); email.put_From("Chilkat Admin <admin@chilkatsoft.com>"); email.AddTo("Chilkat Support","support@chilkatsoft.com"); // Indicate that the email should be sent signed. email.put_SendSigned(true); // Create an instance of a certificate store object, load a PFX file, // locate the certificate we need, and use it for signing. // (a PFX file may contain more than one certificate.) CkCertStore certStore; // The 1st argument is the filename, the 2nd arg is the // PFX file's password: success = certStore.LoadPfxFile("chilkat.pfx","myPassword"); if (success != true) { strOut.append(certStore.lastErrorText()); strOut.append("\r\n"); SetDlgItemText(IDC_EDIT1,strOut.getUnicode()); return; } CkCert *cert = 0; cert = certStore.FindCertBySubject("Chilkat Software, Inc."); if (cert == 0 ) { strOut.append(certStore.lastErrorText()); strOut.append("\r\n"); SetDlgItemText(IDC_EDIT1,strOut.getUnicode()); return; } // This example will use the cert from the certStore... email.SetSigningCert(*cert); // Render the email to signed-MIME. This is where the private // key is accessed and the signing happens. const char * signedMime; signedMime = mailman.renderToMime(email); // Now send the already-signed MIME: const char * fromAddr; const char * recipients; fromAddr = "admin@chilkatsoft.com"; recipients = "support@chilkatsoft.com, matt@chilkatsoft.com"; success = mailman.SendMime(fromAddr,recipients,signedMime); if (success != true) { strOut.append(mailman.lastErrorText()); strOut.append("\r\n"); } else { // The LastErrorText property provides information // even when successful. strOut.append(mailman.lastErrorText()); strOut.append("\r\n"); strOut.append("Mail Sent!\r\n"); } SetDlgItemText(IDC_EDIT1,strOut.getUnicode()); |
Need a specific example? Send a request to support@chilkatsoft.com
© 2000-2008 Chilkat Software, Inc. All Rights Reserved.