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
(Visual FoxPro) P7S - Access Signature Information (date/time, certificate used, etc.)Examine a PKCS7 signature (.p7s) and get information about it. Note: This example requires Chilkat v9.5.0.75 or greater.
LOCAL loBd LOCAL lnSuccess LOCAL loCrypt LOCAL loJson LOCAL i LOCAL lnCount_i LOCAL lcStrVal LOCAL lcCertSerialNumber LOCAL lcCertIssuerCN LOCAL lcCertIssuerDN LOCAL lcCertDigestAlgOid LOCAL lcCertDigestAlgName LOCAL lcContentType LOCAL lcSigningTime LOCAL lcMessageDigest LOCAL lcSigningAlgOid LOCAL lcSignerDigest LOCAL loDt * This requires the Chilkat API to have been previously unlocked. * See Global Unlock Sample for sample code. * First load the .p7s file into a BinData object.. * For versions of Chilkat < 10.0.0, use CreateObject('Chilkat_9_5_0.BinData') loBd = CreateObject('Chilkat.BinData') lnSuccess = loBd.LoadFile("qa_data/p7s/sample.p7s") IF (lnSuccess <> 1) THEN ? "Failed to load .p7s file." RELEASE loBd CANCEL ENDIF * IMPORTANT: This example requires Chilkat v9.5.0.75 or greater. * For versions of Chilkat < 10.0.0, use CreateObject('Chilkat_9_5_0.Crypt2') loCrypt = CreateObject('Chilkat.Crypt2') * Assuming this is a signature that contains the original data that was signed.. lnSuccess = loCrypt.OpaqueVerifyBd(loBd) IF (lnSuccess <> 1) THEN ? loCrypt.LastErrorText RELEASE loBd RELEASE loCrypt CANCEL ENDIF * Examine the LastJsonData after signature verification.. loJson = loCrypt.LastJsonData() loJson.EmitCompact = 0 ? loJson.Emit() * -- * IMPORTANT: This example requires Chilkat v9.5.0.75 or greater. * -- * Sample output... * Go to http://tools.chilkat.io/jsonParse.cshtml * and paste the JSON into the online form to generate JSON parsing code. * { * "pkcs7": { * "verify": { * "digestAlgorithms": [ * "sha256" * ], * "signerInfo": [ * { * "cert": { * "serialNumber": "AAC5FC48C0FD8FBB", * "issuerCN": "AC ABCDEF RFB v5", * "issuerDN": "", * "digestAlgOid": "2.16.840.1.101.3.4.2.1", * "digestAlgName": "SHA-256" * }, * "contentType": "1.2.840.113549.1.7.1", * "signingTime": "180607195054Z", * "messageDigest": "trzyxXbZ96z2M4mncyZ7BNMV4yIT92+5sS27Fu64iG8=", * "signingAlgOid": "1.2.840.113549.1.1.11", * "signerDigest": "trzyxXbZ96z2M4mncyZ7BNMV4yIT92+5sS27Fu64iG8=" * }, * { * "cert": { * "serialNumber": "324FB38ABD59723F", * "issuerCN": "AC ABCDEF RFB v5", * "issuerDN": "", * "digestAlgOid": "2.16.840.1.101.3.4.2.1", * "digestAlgName": "SHA-256" * }, * "contentType": "1.2.840.113549.1.7.1", * "signingTime": "180608182517Z", * "messageDigest": "trzyxXbZ96z2M4mncyZ7BNMV4yIT92+5sS27Fu64iG8=", * "signingAlgOid": "1.2.840.113549.1.1.11", * "signerDigest": "trzyxXbZ96z2M4mncyZ7BNMV4yIT92+5sS27Fu64iG8=" * } * ] * } * } * } * * For versions of Chilkat < 10.0.0, use CreateObject('Chilkat_9_5_0.CkDateTime') loDt = CreateObject('Chilkat.CkDateTime') i = 0 lnCount_i = loJson.SizeOfArray("pkcs7.verify.digestAlgorithms") DO WHILE i < lnCount_i loJson.I = i lcStrVal = loJson.StringOf("pkcs7.verify.digestAlgorithms[i]") i = i + 1 ENDDO i = 0 lnCount_i = loJson.SizeOfArray("pkcs7.verify.signerInfo") DO WHILE i < lnCount_i loJson.I = i lcCertSerialNumber = loJson.StringOf("pkcs7.verify.signerInfo[i].cert.serialNumber") lcCertIssuerCN = loJson.StringOf("pkcs7.verify.signerInfo[i].cert.issuerCN") lcCertIssuerDN = loJson.StringOf("pkcs7.verify.signerInfo[i].cert.issuerDN") lcCertDigestAlgOid = loJson.StringOf("pkcs7.verify.signerInfo[i].cert.digestAlgOid") lcCertDigestAlgName = loJson.StringOf("pkcs7.verify.signerInfo[i].cert.digestAlgName") lcContentType = loJson.StringOf("pkcs7.verify.signerInfo[i].contentType") lcSigningTime = loJson.StringOf("pkcs7.verify.signerInfo[i].signingTime") * The signingTime isin UTCTime format. * UTCTime values take the form of either "YYMMDDhhmm[ss]Z" or "YYMMDDhhmm[ss](+|-)hhmm" * Starting in Chilkat v9.5.0.77, the SetFromTimestamp method auto-recognizes the UTCTime format and parses it correctly. lnSuccess = loDt.SetFromTimestamp(lcSigningTime) * To get the signingTime in other date/time formats, look at the online reference documentation for CkDateTime. * There are numerous methods such as GetAsDateTime, GetAsIso8601, GetAsUnixTime, GetAsRfc822, etc. lcMessageDigest = loJson.StringOf("pkcs7.verify.signerInfo[i].messageDigest") lcSigningAlgOid = loJson.StringOf("pkcs7.verify.signerInfo[i].signingAlgOid") lcSignerDigest = loJson.StringOf("pkcs7.verify.signerInfo[i].signerDigest") i = i + 1 ENDDO RELEASE loJson * println crypt.LastErrorText; ? "Success." RELEASE loBd RELEASE loCrypt RELEASE loDt |
© 2000-2025 Chilkat Software, Inc. All Rights Reserved.