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
(AutoIt) XML-DSig Add EncapsulatedTimestamp when SigningSee more XML Digital Signatures ExamplesDemonstrates how to add an EncapsulatedTimestamp at the time of creating an XML signature. Note: This example requires Chilkat v9.5.0.90 or greater.
; This example requires the Chilkat API to have been previously unlocked. ; See Global Unlock Sample for sample code. Local $bSuccess = True ; Create the folllowing XML to be signed... ; Use this online tool to generate code from sample XML: ; Generate Code to Create XML ; <p:FatturaElettronica xmlns:ds="http://www.w3.org/2000/09/xmldsig#" xmlns:p="http://ivaservizi.agenziaentrate.gov.it/docs/xsd/fatture/v1.2" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" versione="FPR12" xsi:schemaLocation="http://ivaservizi.agenziaentrate.gov.it/docs/xsd/fatture/v1.2 http://www.fatturapa.gov.it/export/fatturazione/sdi/fatturapa/v1.2/Schema_del_file_xml_FatturaPA_versione_1.2.xsd"> ; <FatturaElettronicaHeader> ; <DatiTrasmissione> ; <IdTrasmittente> ; <IdPaese>IT</IdPaese> ; <IdCodice>01234567890</IdCodice> ; </IdTrasmittente> ; <ProgressivoInvio>00001</ProgressivoInvio> ; <FormatoTrasmissione>FPR12</FormatoTrasmissione> ; <CodiceDestinatario>0000000</CodiceDestinatario> ; <PECDestinatario>betagamma@pec.it</PECDestinatario> ; </DatiTrasmissione> ; <CedentePrestatore> ; <DatiAnagrafici> ; <IdFiscaleIVA> ; <IdPaese>IT</IdPaese> ; <IdCodice>01234567890</IdCodice> ; </IdFiscaleIVA> ; <Anagrafica> ; <Denominazione>ALPHA SRL</Denominazione> ; </Anagrafica> ; <RegimeFiscale>RF19</RegimeFiscale> ; </DatiAnagrafici> ; <Sede> ; <Indirizzo>VIALE ROMA 543</Indirizzo> ; <CAP>07100</CAP> ; <Comune>SASSARI</Comune> ; <Provincia>SS</Provincia> ; <Nazione>IT</Nazione> ; </Sede> ; </CedentePrestatore> ; <CessionarioCommittente> ; <DatiAnagrafici> ; <CodiceFiscale>09876543210</CodiceFiscale> ; <Anagrafica> ; <Denominazione>AMMINISTRAZIONE BETA</Denominazione> ; </Anagrafica> ; </DatiAnagrafici> ; <Sede> ; <Indirizzo>VIA TORINO 38-B</Indirizzo> ; <CAP>00145</CAP> ; ; <Comune>ROMA</Comune> ; <Provincia>RM</Provincia> ; <Nazione>IT</Nazione> ; </Sede> ; <StabileOrganizzazione> ; <Indirizzo>VIA CASELLE</Indirizzo> ; <NumeroCivico>4/D</NumeroCivico> ; <CAP>25027</CAP> ; <Comune>QUINZANO D'OGLIO</Comune> ; <Provincia>BS</Provincia> ; <Nazione>IT</Nazione> ; </StabileOrganizzazione> ; <RappresentanteFiscale> ; <IdFiscaleIVA> ; <IdPaese>DE</IdPaese> ; <IdCodice>DE12345</IdCodice> ; </IdFiscaleIVA> ; <Denominazione>RFCC - DENOMINAZIONE</Denominazione> ; </RappresentanteFiscale> ; </CessionarioCommittente> ; </FatturaElettronicaHeader> ; <FatturaElettronicaBody> ; <DatiGenerali> ; <DatiGeneraliDocumento> ; <TipoDocumento>TD01</TipoDocumento> ; <Divisa>EUR</Divisa> ; <Data>2022-03-03</Data> ; <Numero>123</Numero> ; <Causale>LA FATTURA FA RIFERIMENTO AD UNA OPERAZIONE AAAA</Causale> ; <Causale>SEGUE DESCRIZIONE CAUSALE NEL CASO IN CUI NON SIANO STATI SUFFICIENTI 200 CARATTERI AAAAAAAAAAA BBBBBBBBBBBBBBBBB</Causale> ; </DatiGeneraliDocumento> ; <DatiOrdineAcquisto> ; <RiferimentoNumeroLinea>1</RiferimentoNumeroLinea> ; <IdDocumento>66685</IdDocumento> ; <NumItem>1</NumItem> ; <CodiceCUP>123abc</CodiceCUP> ; <CodiceCIG>456def</CodiceCIG> ; </DatiOrdineAcquisto> ; <DatiContratto> ; <RiferimentoNumeroLinea>1</RiferimentoNumeroLinea> ; <IdDocumento>123</IdDocumento> ; <Data>2022-01-01</Data> ; <NumItem>5</NumItem> ; <CodiceCUP>123abc</CodiceCUP> ; <CodiceCIG>456def</CodiceCIG> ; </DatiContratto> ; <DatiConvenzione> ; <RiferimentoNumeroLinea>1</RiferimentoNumeroLinea> ; <IdDocumento>456</IdDocumento> ; <NumItem>5</NumItem> ; <CodiceCUP>123abc</CodiceCUP> ; <CodiceCIG>456def</CodiceCIG> ; </DatiConvenzione> ; <DatiRicezione> ; <RiferimentoNumeroLinea>1</RiferimentoNumeroLinea> ; <IdDocumento>789</IdDocumento> ; <NumItem>5</NumItem> ; <CodiceCUP>123abc</CodiceCUP> ; <CodiceCIG>456def</CodiceCIG> ; </DatiRicezione> ; <DatiTrasporto> ; <DatiAnagraficiVettore> ; <IdFiscaleIVA> ; <IdPaese>IT</IdPaese> ; <IdCodice>24681012141</IdCodice> ; </IdFiscaleIVA> ; <Anagrafica> ; <Denominazione>Trasporto spa</Denominazione> ; </Anagrafica> ; </DatiAnagraficiVettore> ; <DataOraConsegna>2022-03-01T14:26:39</DataOraConsegna> ; </DatiTrasporto> ; </DatiGenerali> ; <DatiBeniServizi> ; <DettaglioLinee> ; <NumeroLinea>1</NumeroLinea> ; <Descrizione>DESCRIZIONE DELLA FORNITURA</Descrizione> ; <Quantita>5.005</Quantita> ; <PrezzoUnitario>1.00</PrezzoUnitario> ; <PrezzoTotale>5.00</PrezzoTotale> ; <AliquotaIVA>22.00</AliquotaIVA> ; </DettaglioLinee> ; <DatiRiepilogo> ; <AliquotaIVA>22.00</AliquotaIVA> ; <ImponibileImporto>5.00</ImponibileImporto> ; <Imposta>1.10</Imposta> ; <EsigibilitaIVA>I</EsigibilitaIVA> ; </DatiRiepilogo> ; </DatiBeniServizi> ; <DatiPagamento> ; <CondizioniPagamento>TP01</CondizioniPagamento> ; <DettaglioPagamento> ; <ModalitaPagamento>MP01</ModalitaPagamento> ; <DataScadenzaPagamento>2017-02-18</DataScadenzaPagamento> ; <ImportoPagamento>6.10</ImportoPagamento> ; </DettaglioPagamento> ; </DatiPagamento> ; </FatturaElettronicaBody> ; </p:FatturaElettronica> $oXmlToSign = ObjCreate("Chilkat.Xml") $oXmlToSign.Tag = "p:FatturaElettronica" $oXmlToSign.AddAttribute("xmlns:ds","http://www.w3.org/2000/09/xmldsig#") $oXmlToSign.AddAttribute("xmlns:p","http://ivaservizi.agenziaentrate.gov.it/docs/xsd/fatture/v1.2") $oXmlToSign.AddAttribute("xmlns:xsi","http://www.w3.org/2001/XMLSchema-instance") $oXmlToSign.AddAttribute("versione","FPR12") $oXmlToSign.AddAttribute("xsi:schemaLocation","http://ivaservizi.agenziaentrate.gov.it/docs/xsd/fatture/v1.2 http://www.fatturapa.gov.it/export/fatturazione/sdi/fatturapa/v1.2/Schema_del_file_xml_FatturaPA_versione_1.2.xsd") $oXmlToSign.UpdateChildContent "FatturaElettronicaHeader|DatiTrasmissione|IdTrasmittente|IdPaese","IT" $oXmlToSign.UpdateChildContent "FatturaElettronicaHeader|DatiTrasmissione|IdTrasmittente|IdCodice","01234567890" $oXmlToSign.UpdateChildContent "FatturaElettronicaHeader|DatiTrasmissione|ProgressivoInvio","00001" $oXmlToSign.UpdateChildContent "FatturaElettronicaHeader|DatiTrasmissione|FormatoTrasmissione","FPR12" $oXmlToSign.UpdateChildContent "FatturaElettronicaHeader|DatiTrasmissione|CodiceDestinatario","0000000" $oXmlToSign.UpdateChildContent "FatturaElettronicaHeader|DatiTrasmissione|PECDestinatario","betagamma@pec.it" $oXmlToSign.UpdateChildContent "FatturaElettronicaHeader|CedentePrestatore|DatiAnagrafici|IdFiscaleIVA|IdPaese","IT" $oXmlToSign.UpdateChildContent "FatturaElettronicaHeader|CedentePrestatore|DatiAnagrafici|IdFiscaleIVA|IdCodice","01234567890" $oXmlToSign.UpdateChildContent "FatturaElettronicaHeader|CedentePrestatore|DatiAnagrafici|Anagrafica|Denominazione","ALPHA SRL" $oXmlToSign.UpdateChildContent "FatturaElettronicaHeader|CedentePrestatore|DatiAnagrafici|RegimeFiscale","RF19" $oXmlToSign.UpdateChildContent "FatturaElettronicaHeader|CedentePrestatore|Sede|Indirizzo","VIALE ROMA 543" $oXmlToSign.UpdateChildContent "FatturaElettronicaHeader|CedentePrestatore|Sede|CAP","07100" $oXmlToSign.UpdateChildContent "FatturaElettronicaHeader|CedentePrestatore|Sede|Comune","SASSARI" $oXmlToSign.UpdateChildContent "FatturaElettronicaHeader|CedentePrestatore|Sede|Provincia","SS" $oXmlToSign.UpdateChildContent "FatturaElettronicaHeader|CedentePrestatore|Sede|Nazione","IT" $oXmlToSign.UpdateChildContent "FatturaElettronicaHeader|CessionarioCommittente|DatiAnagrafici|CodiceFiscale","09876543210" $oXmlToSign.UpdateChildContent "FatturaElettronicaHeader|CessionarioCommittente|DatiAnagrafici|Anagrafica|Denominazione","AMMINISTRAZIONE BETA" $oXmlToSign.UpdateChildContent "FatturaElettronicaHeader|CessionarioCommittente|Sede|Indirizzo","VIA TORINO 38-B" $oXmlToSign.UpdateChildContent "FatturaElettronicaHeader|CessionarioCommittente|Sede|CAP","00145" $oXmlToSign.UpdateChildContent "FatturaElettronicaHeader|CessionarioCommittente|Sede|Comune","ROMA" $oXmlToSign.UpdateChildContent "FatturaElettronicaHeader|CessionarioCommittente|Sede|Provincia","RM" $oXmlToSign.UpdateChildContent "FatturaElettronicaHeader|CessionarioCommittente|Sede|Nazione","IT" $oXmlToSign.UpdateChildContent "FatturaElettronicaHeader|CessionarioCommittente|StabileOrganizzazione|Indirizzo","VIA CASELLE" $oXmlToSign.UpdateChildContent "FatturaElettronicaHeader|CessionarioCommittente|StabileOrganizzazione|NumeroCivico","4/D" $oXmlToSign.UpdateChildContent "FatturaElettronicaHeader|CessionarioCommittente|StabileOrganizzazione|CAP","25027" $oXmlToSign.UpdateChildContent "FatturaElettronicaHeader|CessionarioCommittente|StabileOrganizzazione|Comune","QUINZANO D'OGLIO" $oXmlToSign.UpdateChildContent "FatturaElettronicaHeader|CessionarioCommittente|StabileOrganizzazione|Provincia","BS" $oXmlToSign.UpdateChildContent "FatturaElettronicaHeader|CessionarioCommittente|StabileOrganizzazione|Nazione","IT" $oXmlToSign.UpdateChildContent "FatturaElettronicaHeader|CessionarioCommittente|RappresentanteFiscale|IdFiscaleIVA|IdPaese","DE" $oXmlToSign.UpdateChildContent "FatturaElettronicaHeader|CessionarioCommittente|RappresentanteFiscale|IdFiscaleIVA|IdCodice","DE12345" $oXmlToSign.UpdateChildContent "FatturaElettronicaHeader|CessionarioCommittente|RappresentanteFiscale|Denominazione","RFCC - DENOMINAZIONE" $oXmlToSign.UpdateChildContent "FatturaElettronicaBody|DatiGenerali|DatiGeneraliDocumento|TipoDocumento","TD01" $oXmlToSign.UpdateChildContent "FatturaElettronicaBody|DatiGenerali|DatiGeneraliDocumento|Divisa","EUR" $oXmlToSign.UpdateChildContent "FatturaElettronicaBody|DatiGenerali|DatiGeneraliDocumento|Data","2022-03-03" $oXmlToSign.UpdateChildContent "FatturaElettronicaBody|DatiGenerali|DatiGeneraliDocumento|Numero","123" $oXmlToSign.UpdateChildContent "FatturaElettronicaBody|DatiGenerali|DatiGeneraliDocumento|Causale","LA FATTURA FA RIFERIMENTO AD UNA OPERAZIONE AAAA" $oXmlToSign.UpdateChildContent "FatturaElettronicaBody|DatiGenerali|DatiGeneraliDocumento|Causale[1]","SEGUE DESCRIZIONE CAUSALE NEL CASO IN CUI NON SIANO STATI SUFFICIENTI 200 CARATTERI AAAAAAAAAAA BBBBBBBBBBBBBBBBB" $oXmlToSign.UpdateChildContent "FatturaElettronicaBody|DatiGenerali|DatiOrdineAcquisto|RiferimentoNumeroLinea","1" $oXmlToSign.UpdateChildContent "FatturaElettronicaBody|DatiGenerali|DatiOrdineAcquisto|IdDocumento","66685" $oXmlToSign.UpdateChildContent "FatturaElettronicaBody|DatiGenerali|DatiOrdineAcquisto|NumItem","1" $oXmlToSign.UpdateChildContent "FatturaElettronicaBody|DatiGenerali|DatiOrdineAcquisto|CodiceCUP","123abc" $oXmlToSign.UpdateChildContent "FatturaElettronicaBody|DatiGenerali|DatiOrdineAcquisto|CodiceCIG","456def" $oXmlToSign.UpdateChildContent "FatturaElettronicaBody|DatiGenerali|DatiContratto|RiferimentoNumeroLinea","1" $oXmlToSign.UpdateChildContent "FatturaElettronicaBody|DatiGenerali|DatiContratto|IdDocumento","123" $oXmlToSign.UpdateChildContent "FatturaElettronicaBody|DatiGenerali|DatiContratto|Data","2022-01-01" $oXmlToSign.UpdateChildContent "FatturaElettronicaBody|DatiGenerali|DatiContratto|NumItem","5" $oXmlToSign.UpdateChildContent "FatturaElettronicaBody|DatiGenerali|DatiContratto|CodiceCUP","123abc" $oXmlToSign.UpdateChildContent "FatturaElettronicaBody|DatiGenerali|DatiContratto|CodiceCIG","456def" $oXmlToSign.UpdateChildContent "FatturaElettronicaBody|DatiGenerali|DatiConvenzione|RiferimentoNumeroLinea","1" $oXmlToSign.UpdateChildContent "FatturaElettronicaBody|DatiGenerali|DatiConvenzione|IdDocumento","456" $oXmlToSign.UpdateChildContent "FatturaElettronicaBody|DatiGenerali|DatiConvenzione|NumItem","5" $oXmlToSign.UpdateChildContent "FatturaElettronicaBody|DatiGenerali|DatiConvenzione|CodiceCUP","123abc" $oXmlToSign.UpdateChildContent "FatturaElettronicaBody|DatiGenerali|DatiConvenzione|CodiceCIG","456def" $oXmlToSign.UpdateChildContent "FatturaElettronicaBody|DatiGenerali|DatiRicezione|RiferimentoNumeroLinea","1" $oXmlToSign.UpdateChildContent "FatturaElettronicaBody|DatiGenerali|DatiRicezione|IdDocumento","789" $oXmlToSign.UpdateChildContent "FatturaElettronicaBody|DatiGenerali|DatiRicezione|NumItem","5" $oXmlToSign.UpdateChildContent "FatturaElettronicaBody|DatiGenerali|DatiRicezione|CodiceCUP","123abc" $oXmlToSign.UpdateChildContent "FatturaElettronicaBody|DatiGenerali|DatiRicezione|CodiceCIG","456def" $oXmlToSign.UpdateChildContent "FatturaElettronicaBody|DatiGenerali|DatiTrasporto|DatiAnagraficiVettore|IdFiscaleIVA|IdPaese","IT" $oXmlToSign.UpdateChildContent "FatturaElettronicaBody|DatiGenerali|DatiTrasporto|DatiAnagraficiVettore|IdFiscaleIVA|IdCodice","24681012141" $oXmlToSign.UpdateChildContent "FatturaElettronicaBody|DatiGenerali|DatiTrasporto|DatiAnagraficiVettore|Anagrafica|Denominazione","Trasporto spa" $oXmlToSign.UpdateChildContent "FatturaElettronicaBody|DatiGenerali|DatiTrasporto|DataOraConsegna","2022-03-01T14:26:39" $oXmlToSign.UpdateChildContent "FatturaElettronicaBody|DatiBeniServizi|DettaglioLinee|NumeroLinea","1" $oXmlToSign.UpdateChildContent "FatturaElettronicaBody|DatiBeniServizi|DettaglioLinee|Descrizione","DESCRIZIONE DELLA FORNITURA" $oXmlToSign.UpdateChildContent "FatturaElettronicaBody|DatiBeniServizi|DettaglioLinee|Quantita","5.005" $oXmlToSign.UpdateChildContent "FatturaElettronicaBody|DatiBeniServizi|DettaglioLinee|PrezzoUnitario","1.00" $oXmlToSign.UpdateChildContent "FatturaElettronicaBody|DatiBeniServizi|DettaglioLinee|PrezzoTotale","5.00" $oXmlToSign.UpdateChildContent "FatturaElettronicaBody|DatiBeniServizi|DettaglioLinee|AliquotaIVA","22.00" $oXmlToSign.UpdateChildContent "FatturaElettronicaBody|DatiBeniServizi|DatiRiepilogo|AliquotaIVA","22.00" $oXmlToSign.UpdateChildContent "FatturaElettronicaBody|DatiBeniServizi|DatiRiepilogo|ImponibileImporto","5.00" $oXmlToSign.UpdateChildContent "FatturaElettronicaBody|DatiBeniServizi|DatiRiepilogo|Imposta","1.10" $oXmlToSign.UpdateChildContent "FatturaElettronicaBody|DatiBeniServizi|DatiRiepilogo|EsigibilitaIVA","I" $oXmlToSign.UpdateChildContent "FatturaElettronicaBody|DatiPagamento|CondizioniPagamento","TP01" $oXmlToSign.UpdateChildContent "FatturaElettronicaBody|DatiPagamento|DettaglioPagamento|ModalitaPagamento","MP01" $oXmlToSign.UpdateChildContent "FatturaElettronicaBody|DatiPagamento|DettaglioPagamento|DataScadenzaPagamento","2017-02-18" $oXmlToSign.UpdateChildContent "FatturaElettronicaBody|DatiPagamento|DettaglioPagamento|ImportoPagamento","6.10" $oGen = ObjCreate("Chilkat.XmlDSigGen") $oGen.SigLocation = "p:FatturaElettronica" $oGen.SigLocationMod = 0 $oGen.SigId = "signature-5580-7534-6530-8286" $oGen.AddSignatureNamespace("xadesv1410","http://uri.etsi.org/01903/v1.4.1") $oGen.AddSignatureNamespace("xades","http://uri.etsi.org/01903/v1.3.2#") ; xmlRoot tag = p:FatturaElettronica ; has xmlns:ds! $oGen.SigValueId = "signature-value-5957-3819-1360-0727" $oGen.SignedInfoCanonAlg = "EXCL_C14N" $oGen.SignedInfoDigestMethod = "sha256" ; Set the KeyInfoId before adding references.. $oGen.KeyInfoId = "key-info-7422-1087-7530-8569" ; Create the following signed properties object to be added to the signature: ; Use this online tool to generate code from sample XML: ; Generate Code to Create XML ; <xades:QualifyingProperties Target="#signature-5580-7534-6530-8286"> ; <xades:SignedProperties Id="signed-properties-1545-8800-2160-3000"> ; <xades:SignedSignatureProperties> ; <xades:SigningTime>TO BE GENERATED BY CHILKAT</xades:SigningTime> ; <xades:SigningCertificate> ; <xades:Cert> ; <xades:CertDigest> ; <ds:DigestMethod Algorithm="http://www.w3.org/2001/04/xmlenc#sha256"/> ; <ds:DigestValue>TO BE GENERATED BY CHILKAT</ds:DigestValue> ; ; </xades:CertDigest> ; <xades:IssuerSerial> ; <ds:X509IssuerName>TO BE GENERATED BY CHILKAT</ds:X509IssuerName> ; <ds:X509SerialNumber>TO BE GENERATED BY CHILKAT</ds:X509SerialNumber> ; </xades:IssuerSerial> ; </xades:Cert> ; </xades:SigningCertificate> ; </xades:SignedSignatureProperties> ; </xades:SignedProperties> ; <xades:UnsignedProperties> ; <xades:UnsignedSignatureProperties> ; <xades:SignatureTimeStamp Id="signature-timestamp-5561-8212-3316-5191"> ; <ds:CanonicalizationMethod Algorithm="http://www.w3.org/2001/10/xml-exc-c14n#"/> ; <xades:EncapsulatedTimeStamp Encoding="http://uri.etsi.org/01903/v1.2.2#DER">TO BE GENERATED BY CHILKAT</xades:EncapsulatedTimeStamp> ; </xades:SignatureTimeStamp> ; </xades:UnsignedSignatureProperties> ; </xades:UnsignedProperties> ; </xades:QualifyingProperties> ; Note: Chilkat will automatically fill in the values marked as "TO BE GENERATED BY CHILKAT" at the time of signing. ; The EncapsulatedTimestamp will be automatically generated. $oObject1 = ObjCreate("Chilkat.Xml") $oObject1.Tag = "xades:QualifyingProperties" $oObject1.AddAttribute("Target","#signature-5580-7534-6530-8286") $oObject1.UpdateAttrAt("xades:SignedProperties",True,"Id","signed-properties-1545-8800-2160-3000") $oObject1.UpdateChildContent "xades:SignedProperties|xades:SignedSignatureProperties|xades:SigningTime","TO BE GENERATED BY CHILKAT" $oObject1.UpdateAttrAt("xades:SignedProperties|xades:SignedSignatureProperties|xades:SigningCertificate|xades:Cert|xades:CertDigest|ds:DigestMethod",True,"Algorithm","http://www.w3.org/2001/04/xmlenc#sha256") $oObject1.UpdateChildContent "xades:SignedProperties|xades:SignedSignatureProperties|xades:SigningCertificate|xades:Cert|xades:CertDigest|ds:DigestValue","TO BE GENERATED BY CHILKAT" $oObject1.UpdateChildContent "xades:SignedProperties|xades:SignedSignatureProperties|xades:SigningCertificate|xades:Cert|xades:IssuerSerial|ds:X509IssuerName","TO BE GENERATED BY CHILKAT" $oObject1.UpdateChildContent "xades:SignedProperties|xades:SignedSignatureProperties|xades:SigningCertificate|xades:Cert|xades:IssuerSerial|ds:X509SerialNumber","TO BE GENERATED BY CHILKAT" $oObject1.UpdateAttrAt("xades:UnsignedProperties|xades:UnsignedSignatureProperties|xades:SignatureTimeStamp",True,"Id","signature-timestamp-5561-8212-3316-5191") $oObject1.UpdateAttrAt("xades:UnsignedProperties|xades:UnsignedSignatureProperties|xades:SignatureTimeStamp|ds:CanonicalizationMethod",True,"Algorithm","http://www.w3.org/2001/10/xml-exc-c14n#") $oObject1.UpdateAttrAt("xades:UnsignedProperties|xades:UnsignedSignatureProperties|xades:SignatureTimeStamp|xades:EncapsulatedTimeStamp",True,"Encoding","http://uri.etsi.org/01903/v1.2.2#DER") $oObject1.UpdateChildContent "xades:UnsignedProperties|xades:UnsignedSignatureProperties|xades:SignatureTimeStamp|xades:EncapsulatedTimeStamp","TO BE GENERATED BY CHILKAT" $oGen.AddObject("signature-object-8923-2359-1722-2161",$oObject1.GetXml(),"","") ; -------- Reference 1 -------- ; <ds:Transforms> ; <ds:Transform Algorithm="http://www.w3.org/2002/06/xmldsig-filter2"> ; <dsig-xpath:XPath xmlns:dsig-xpath="http://www.w3.org/2002/06/xmldsig-filter2" Filter="subtract">/descendant::ds:Signature</dsig-xpath:XPath> ; </ds:Transform> ; <ds:Transform Algorithm="http://www.w3.org/2001/10/xml-exc-c14n#"/> ; </ds:Transforms> $oXml1 = ObjCreate("Chilkat.Xml") $oXml1.Tag = "ds:Transforms" $oXml1.UpdateAttrAt("ds:Transform",True,"Algorithm","http://www.w3.org/2002/06/xmldsig-filter2") $oXml1.UpdateAttrAt("ds:Transform|dsig-xpath:XPath",True,"xmlns:dsig-xpath","http://www.w3.org/2002/06/xmldsig-filter2") $oXml1.UpdateAttrAt("ds:Transform|dsig-xpath:XPath",True,"Filter","subtract") $oXml1.UpdateChildContent "ds:Transform|dsig-xpath:XPath","/descendant::ds:Signature" $oXml1.UpdateAttrAt("ds:Transform[1]",True,"Algorithm","http://www.w3.org/2001/10/xml-exc-c14n#") $oGen.AddSameDocRef2("","sha256",$oXml1,"") ; -------- Reference 2 -------- ; <ds:Transforms> ; <ds:Transform Algorithm="http://www.w3.org/2001/10/xml-exc-c14n#"/> ; </ds:Transforms> $oXml2 = ObjCreate("Chilkat.Xml") $oXml2.Tag = "ds:Transforms" $oXml2.UpdateAttrAt("ds:Transform",True,"Algorithm","http://www.w3.org/2001/10/xml-exc-c14n#") $oGen.AddObjectRef2("signed-properties-1545-8800-2160-3000","sha256",$oXml2,"http://uri.etsi.org/01903#SignedProperties") ; Provide a certificate + private key. (PFX password is test123) $oCert = ObjCreate("Chilkat.Cert") $bSuccess = $oCert.LoadPfxFile("qa_data/pfx/cert_test123.pfx","test123") If ($bSuccess <> True) Then ConsoleWrite($oCert.LastErrorText & @CRLF) Exit EndIf $oGen.SetX509Cert($oCert,True) $oGen.KeyInfoType = "X509Data+KeyValue" $oGen.X509Type = "Certificate" ; Load XML to be signed... $oSbXml = ObjCreate("Chilkat.StringBuilder") $oXmlToSign.GetXmlSb($oSbXml) $oGen.Behaviors = "IndentedSignature,OmitAlreadyDefinedSigNamespace" ; ------------------------------------------------------------------------------------------- ; To have the EncapsulatedTimeStamp automatically added, we only need to do 2 things. ; 1) Add the <xades:EncapsulatedTimeStamp Encoding="http://uri.etsi.org/01903/v1.2.2#DER">TO BE GENERATED BY CHILKAT</xades:EncapsulatedTimeStamp> ; to the unsigned properties. ; 2) Specify the TSA URL (Timestamping Authority URL). ; Here we specify the TSA URL: ; ------------------------------------------------------------------------------------------- $oJsonTsa = ObjCreate("Chilkat.JsonObject") $oJsonTsa.UpdateString("timestampToken.tsaUrl","http://timestamp.digicert.com") $oJsonTsa.UpdateBool("timestampToken.requestTsaCert",True) $oGen.SetTsa($oJsonTsa) ; Sign the XML... $bSuccess = $oGen.CreateXmlDSigSb($oSbXml) If ($bSuccess <> True) Then ConsoleWrite($oGen.LastErrorText & @CRLF) Exit EndIf ; Save the signed XML to a file. $bSuccess = $oSbXml.WriteFile("qa_output/signedXml.xml","utf-8",False) ; ---------------------------------------- ; Verify the signatures we just produced... $oVerifier = ObjCreate("Chilkat.XmlDSig") $bSuccess = $oVerifier.LoadSignatureSb($oSbXml) If ($bSuccess <> True) Then ConsoleWrite($oVerifier.LastErrorText & @CRLF) Exit EndIf ; Add "VerifyEncapsulatedTimeStamp" to the UncommonOptions to also verify any EncapsulatedTimeStamps $oVerifier.UncommonOptions = "VerifyEncapsulatedTimeStamp" Local $iNumSigs = $oVerifier.NumSignatures Local $iVerifyIdx = 0 While $iVerifyIdx < $iNumSigs $oVerifier.Selector = $iVerifyIdx Local $bVerified = $oVerifier.VerifySignature(True) If ($bVerified <> True) Then ConsoleWrite($oVerifier.LastErrorText & @CRLF) Exit EndIf $iVerifyIdx = $iVerifyIdx + 1 Wend ConsoleWrite("All signatures were successfully verified." & @CRLF) |
© 2000-2024 Chilkat Software, Inc. All Rights Reserved.