Chilkat HOME .NET Core C# Android™ AutoIt C C# C++ Chilkat2-Python CkPython Classic ASP DataFlex Delphi ActiveX Delphi DLL Go Java Lianja Mono C# Node.js Objective-C PHP ActiveX PHP Extension Perl PowerBuilder PowerShell PureBasic Ruby SQL Server Swift 2 Swift 3,4,5... Tcl Unicode C Unicode C++ VB.NET VBScript Visual Basic 6.0 Visual FoxPro Xojo Plugin
(PowerBuilder) Verify a .p7m and get Algorithm InformationDemonstrates how to verify a .p7m and then examine the algorithms used by the signature.
integer li_rc oleobject loo_Crypt string ls_InFile string ls_OutFile integer li_Success oleobject loo_Json integer i integer li_Count_i string ls_StrVal string ls_CertSerialNumber string ls_CertIssuerCN string ls_CertIssuerDN string ls_CertDigestAlgOid string ls_CertDigestAlgName string ls_ContentType string ls_SigningTime string ls_MessageDigest string ls_SigningAlgOid string ls_SignerDigest integer j integer li_Count_j string ls_Oid string ls_OidName string ls_Der // This example requires the Chilkat API to have been previously unlocked. // See Global Unlock Sample for sample code. loo_Crypt = create oleobject // Use "Chilkat_9_5_0.Crypt2" for versions of Chilkat < 10.0.0 li_rc = loo_Crypt.ConnectToNewObject("Chilkat.Crypt2") if li_rc < 0 then destroy loo_Crypt MessageBox("Error","Connecting to COM object failed") return end if ls_InFile = "qa_data/p7m/brainpoolP256r1.p7m" ls_OutFile = "qa_output/something.dat" // Verify and extract the signed data. li_Success = loo_Crypt.VerifyP7M(ls_InFile,ls_OutFile) if li_Success = 0 then Write-Debug loo_Crypt.LastErrorText destroy loo_Crypt return end if // Examine details about the signature(s) loo_Json = loo_Crypt.LastJsonData() loo_Json.EmitCompact = 0 Write-Debug loo_Json.Emit() // Sample output // { // "pkcs7": { // "verify": { // "digestAlgorithms": [ // "sha256" // ], // "signerInfo": [ // { // "cert": { // "serialNumber": "FFFFE552B302FFFFFF1E34C3ACEB2FFFF", // "issuerCN": "The common name of the cert...", // "issuerDN": "", // "digestAlgOid": "2.16.840.1.101.3.4.2.1", // "digestAlgName": "SHA256" // }, // "contentType": "1.2.840.113549.1.7.1", // "signingTime": "190409140500Z", // "messageDigest": "lQe9If7vZKFf/NlSYu5Esmlw3phVK/RFsbbb1uH73t8=", // "signingAlgOid": "1.2.840.10045.4.3.2", // "signerDigest": "lQe9If7vZKFf/NlSYu5Esmlw3phVK/RFsbbb1uH73t8=", // "authAttr": [ // { // "oid": "1.2.840.113549.1.9.3", // "oidName": "contentType" // }, // { // "oid": "1.2.840.113549.1.9.5", // "oidName": "signingTime" // }, // { // "oid": "1.2.840.113549.1.9.52", // "oidName": "1.2.840.113549.1.9.52", // "der": "MBs ... AwI=" // }, // { // "oid": "1.2.840.113549.1.9.4", // "oidName": "messageDigest" // }, // { // "oid": "1.2.840.113549.1.9.16.2.47", // "oidName": "signingCertificateV2", // "der": "MCYw .. 7PlQ==" // }, // { // "oid": "1.2.840.113549.1.9.20", // "oidName": "1.2.840.113549.1.9.20" // } // ] // } // ] // } // } // } // Code for parsing the above JSON... i = 0 li_Count_i = loo_Json.SizeOfArray("pkcs7.verify.digestAlgorithms") do while i < li_Count_i loo_Json.I = i ls_StrVal = loo_Json.StringOf("pkcs7.verify.digestAlgorithms[i]") i = i + 1 loop i = 0 li_Count_i = loo_Json.SizeOfArray("pkcs7.verify.signerInfo") do while i < li_Count_i loo_Json.I = i ls_CertSerialNumber = loo_Json.StringOf("pkcs7.verify.signerInfo[i].cert.serialNumber") ls_CertIssuerCN = loo_Json.StringOf("pkcs7.verify.signerInfo[i].cert.issuerCN") ls_CertIssuerDN = loo_Json.StringOf("pkcs7.verify.signerInfo[i].cert.issuerDN") ls_CertDigestAlgOid = loo_Json.StringOf("pkcs7.verify.signerInfo[i].cert.digestAlgOid") ls_CertDigestAlgName = loo_Json.StringOf("pkcs7.verify.signerInfo[i].cert.digestAlgName") ls_ContentType = loo_Json.StringOf("pkcs7.verify.signerInfo[i].contentType") ls_SigningTime = loo_Json.StringOf("pkcs7.verify.signerInfo[i].signingTime") ls_MessageDigest = loo_Json.StringOf("pkcs7.verify.signerInfo[i].messageDigest") ls_SigningAlgOid = loo_Json.StringOf("pkcs7.verify.signerInfo[i].signingAlgOid") ls_SignerDigest = loo_Json.StringOf("pkcs7.verify.signerInfo[i].signerDigest") j = 0 li_Count_j = loo_Json.SizeOfArray("pkcs7.verify.signerInfo[i].authAttr") do while j < li_Count_j loo_Json.J = j ls_Oid = loo_Json.StringOf("pkcs7.verify.signerInfo[i].authAttr[j].oid") ls_OidName = loo_Json.StringOf("pkcs7.verify.signerInfo[i].authAttr[j].oidName") ls_Der = loo_Json.StringOf("pkcs7.verify.signerInfo[i].authAttr[j].der") j = j + 1 loop i = i + 1 loop destroy loo_Json Write-Debug "Success!" destroy loo_Crypt |
© 2000-2024 Chilkat Software, Inc. All Rights Reserved.