Visual Basic 6.0
Visual Basic 6.0
Italian FatturaPA (e-Invoice) Signed XML (CADES-BES P7M) using USB SmartCard Reader
See more CAdES Examples
Demonstrates Italian e-Invoice (FatturaPA) signing by using a private key stored on a USB smartcard reader.Chilkat Visual Basic 6.0 Downloads
Dim success As Long
success = 0
' This example assumes the Chilkat API to have been previously unlocked.
' See Global Unlock Sample for sample code.
Dim crypt As New ChilkatCrypt2
crypt.VerboseLogging = 1
Dim cert As New ChilkatCert
' Use your smart card user PIN for signing.
cert.SmartCardPin = "0000"
success = cert.LoadFromSmartcard("")
If (success = 0) Then
Debug.Print cert.LastErrorText
Exit Sub
End If
success = crypt.SetSigningCert(cert)
If (success = 0) Then
Debug.Print crypt.LastErrorText
Exit Sub
End If
' The CadesEnabled property applies to all methods that create PKCS7 signatures.
' To create a CAdES-BES signature, set this property equal to true.
crypt.CadesEnabled = 1
crypt.HashAlgorithm = "sha256"
Dim signedAttrs As New ChilkatJsonObject
success = signedAttrs.UpdateInt("contentType",1)
success = signedAttrs.UpdateInt("signingTime",1)
success = signedAttrs.UpdateInt("messageDigest",1)
success = signedAttrs.UpdateInt("signingCertificateV2",1)
crypt.SigningAttributes = signedAttrs.Emit()
' Load XML such as the following:
' <p:FatturaElettronica xmlns:p="http://ivaservizi.agenziaentrate.gov.it/docs/xsd/fatture/v1.2" versione="FPR12">
' <FatturaElettronicaHeader>
' <DatiTrasmissione>
' ...
' </DatiTrasmissione>
' <CedentePrestatore>
' ...
' </CedentePrestatore>
' <CessionarioCommittente>
' ...
' </CessionarioCommittente>
' </FatturaElettronicaHeader>
' <FatturaElettronicaBody>
' <DatiGenerali>
' <DatiGeneraliDocumento>
' ...
' </DatiGeneraliDocumento>
' </DatiGenerali>
' <DatiBeniServizi>
' ...
' </DatiBeniServizi>
' </FatturaElettronicaBody>
' </p:FatturaElettronica>
Dim inputXmlPath As String
inputXmlPath = "c:/someDir/e-Invoice.xml"
Dim outputP7mPath As String
outputP7mPath = "c:/someDir/signed.p7m"
' Create the CAdES-BES attached signature, which contains the original data.
success = crypt.CreateP7M(inputXmlPath,outputP7mPath)
If (success = 0) Then
Debug.Print crypt.LastErrorText
Exit Sub
End If
Debug.Print "Success."