Sample code for 30+ languages & platforms
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

Visual Basic 6.0
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."