Chilkat  HOME  Android™  Classic ASP  C  C++  C#  Mono C#  .NET Core C#  C# UWP/WinRT  DataFlex  Delphi ActiveX  Delphi DLL  Visual FoxPro  Java  Lianja  MFC  Objective-C  Perl  PHP ActiveX  PHP Extension  PowerBuilder  PowerShell  PureBasic  CkPython  Chilkat2-Python  Ruby  SQL Server  Swift 2  Swift 3,4,5...  Tcl  Unicode C  Unicode C++  Visual Basic 6.0  VB.NET  VB.NET UWP/WinRT  VBScript  Xojo Plugin  Node.js  Excel  Go
 
      (Excel) Combine Timestamp Reply and Content File into a TimeStampDataDemonstrates how to combine a timestamp reply (RFC 3161) with a data file (any type of file) to create a TimeStampData structure (RFC 5544). 
 ' This example requires the Chilkat API to have been previously unlocked. ' See Global Unlock Sample for sample code. ' Also see this example: ' Send a TimeStamp Request to a TimeStamp Authority and get the Response ' Load a timestamp reply file Dim bdTsr As Chilkat.BinData Set bdTsr = Chilkat.NewBinData success = bdTsr.LoadFile("qa_data/tsd/sample.tsr") If (success <> True) Then Debug.Print "Failed to load timestamp reply file." Exit Sub End If ' Load the tsr into an ASN.1 object. Dim asnTsr As Chilkat.Asn Set asnTsr = Chilkat.NewAsn success = asnTsr.LoadEncoded(bdTsr.GetEncoded("base64"),"base64") If (success <> True) Then Debug.Print asnTsr.LastErrorText Exit Sub End If ' Get the timestamp reply as XML. Dim xmlTsr As Chilkat.Xml Set xmlTsr = Chilkat.NewXml success = xmlTsr.LoadXml(asnTsr.AsnToXml()) ' The timestamp reply XML begins like this: ' We'll want to remove the 1st "sequence" subtree. ' <?xml version="1.0" encoding="utf-8"?> ' <sequence> ' <sequence> <---- Remove this sub-tree. ' <int>00</int> ' <sequence> ' <utf8>Operation Okay</utf8> ' </sequence> ' </sequence> ' <sequence> ' <oid>1.2.840.113549.1.7.2</oid> ' <contextSpecific tag="0" constructed="1"> ' ... ' Remove the 1st sub-tree.. xmlTsr.RemoveChildByIndex 0 ' In this example, the data file we're combining with the timestamp into a timestampData is a .p7m. ' However, it can be any type of file (text or binary), it doesn't matter.. Dim bdContent As Chilkat.BinData Set bdContent = Chilkat.NewBinData success = bdContent.LoadFile("qa_data/tsd/sample.p7m") If (success <> True) Then Debug.Print "Failed to load content file." Exit Sub End If ' Begin building the TimeStampData. ' We'll build as XML and then convert to ASN.1 Dim xml As Chilkat.Xml Set xml = Chilkat.NewXml xml.Tag = "sequence" xml.UpdateChildContent "oid","1.2.840.113549.1.9.16.1.31" success = xml.UpdateAttrAt("contextSpecific",True,"tag","0") success = xml.UpdateAttrAt("contextSpecific",True,"constructed","1") xml.UpdateChildContent "contextSpecific|sequence|int","01" xml.UpdateChildContent "contextSpecific|sequence|octets",bdContent.GetEncoded("base64") success = xml.UpdateAttrAt("contextSpecific|sequence|contextSpecific",True,"tag","0") success = xml.UpdateAttrAt("contextSpecific|sequence|contextSpecific",True,"constructed","1") Set xContext = xml.GetChildWithTag("contextSpecific|sequence|contextSpecific") success = xContext.AddChildTree(xmlTsr) ' Convert the XML to ASN.1 Dim tsd As Chilkat.Asn Set tsd = Chilkat.NewAsn success = tsd.LoadAsnXml(xml.GetXml()) ' Write the timestamped data to a file. success = tsd.WriteBinaryDer("qa_output/sample.tsd") ' Alternatively, get the tsd ASN.1 as base64.. tsdBase64 = tsd.GetEncodedDer("base64_mime") Debug.Print tsdBase64  | 
  ||||
© 2000-2022 Chilkat Software, Inc. All Rights Reserved.