|  | 
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
| (PureBasic) ConvertToSignedPkDemonstrates how to digitally sign MIME to create an "opaque" signature. The MIME is converted to an application/x-pkcs7-mime which is a PKCS7 signature that includes both the original MIME message and the signature. This is different than AddDetachedSignaturePk, where the signature is appended to the MIME. This example demonstrates how to use the certificate and its corresponding private key when they are stored in separate files -- a .cer for the certificate, and a .pem for the private key. 
 IncludeFile "CkCert.pb" IncludeFile "CkMime.pb" IncludeFile "CkPrivateKey.pb" Procedure ChilkatExample() ; This example assumes the Chilkat API to have been previously unlocked. ; See Global Unlock Sample for sample code. mime.i = CkMime::ckCreate() If mime.i = 0 Debug "Failed to create object." ProcedureReturn EndIf ; Load the certificate from a .cer file. cert.i = CkCert::ckCreate() If cert.i = 0 Debug "Failed to create object." ProcedureReturn EndIf success.i = CkCert::ckLoadFromFile(cert,"aaworkarea/myCert.cer") If success = 0 Debug CkCert::ckLastErrorText(cert) CkMime::ckDispose(mime) CkCert::ckDispose(cert) ProcedureReturn EndIf ; Load the private key from an encrypted PEM file. ; (A private key can be loaded from other file formats also..) privKey.i = CkPrivateKey::ckCreate() If privKey.i = 0 Debug "Failed to create object." ProcedureReturn EndIf success = CkPrivateKey::ckLoadEncryptedPemFile(privKey,"aaworkarea/myPrivateKey.pem","myPassword") If success = 0 Debug CkPrivateKey::ckLastErrorText(privKey) CkMime::ckDispose(mime) CkCert::ckDispose(cert) CkPrivateKey::ckDispose(privKey) ProcedureReturn EndIf success = CkMime::ckSetBodyFromPlainText(mime,"This is the plain-text MIME body.") ; Convert the MIME to application/x-pkcs7-mime, which ; is PKCS7 containing both the original content and the signature. success = CkMime::ckConvertToSignedPk(mime,cert,privKey) If success = 0 Debug CkMime::ckLastErrorText(mime) CkMime::ckDispose(mime) CkCert::ckDispose(cert) CkPrivateKey::ckDispose(privKey) ProcedureReturn EndIf ; Save the S/MIME to a file. success = CkMime::ckSaveMime(mime,"aaworkarea/opaqueSignedMime.txt") If success = 0 Debug CkMime::ckLastErrorText(mime) CkMime::ckDispose(mime) CkCert::ckDispose(cert) CkPrivateKey::ckDispose(privKey) ProcedureReturn EndIf Debug "success!" CkMime::ckDispose(mime) CkCert::ckDispose(cert) CkPrivateKey::ckDispose(privKey) ProcedureReturn EndProcedure | ||||
© 2000-2025 Chilkat Software, Inc. All Rights Reserved.