Compartir a través de


Firmar un documento

[CAPICOM es un componente solo de 32 bits que está disponible para su uso en los siguientes sistemas operativos: Windows Server 2008, Windows Vista y Windows XP. En su lugar, use .NET Framework para implementar características de seguridad. Para obtener más información, vea Alternativas al uso de CAPICOM.

Un uso estándar de una firma es firmar un texto y guardar ese texto firmado en un archivo. El texto firmado también se puede enviar a través de Internet. El mensaje firmado está en formato PKCS #7.

En este ejemplo, la firma se crea para el contenido desasociado (cuando el contenido no se incluye con la firma). Una firma desasociada se usaría con más frecuencia si el destinatario de la firma tiene una copia del texto firmado exacto. En el ejemplo siguiente, el mensaje original y la firma desasociada se escriben en archivos independientes.

En cualquier error CAPICOM, se devuelve un valor decimal negativo de Err.Number . Para obtener más información, consulte CAPICOM_ERROR_CODE. Para obtener información sobre los valores decimales positivos de Err.Number, consulte Winerror.h.

La creación de una firma usa la clave privada del firmante. Solo se puede crear una firma si el certificado del firmante con una clave privada asociada está disponible. En este ejemplo del método Sign no se especifica un firmante. Si no se especifica un firmante y no hay ningún certificado en CAPICOM_MY_STORE tiene una clave privada asociada, se produce un error en el método Sign . Si uno y solo un certificado de CAPICOM_MY_STORE tiene una clave privada asociada, ese certificado y su clave privada se usan para crear la firma. Si más de un certificado del almacén de CAPICOM_MY_STORE tiene una clave privada asociada, aparece un cuadro de diálogo y el usuario puede elegir el certificado que se usará para crear la firma.

Cuando una aplicación basada en web usa el método Sign , siempre se muestra un mensaje y se requiere el permiso del usuario antes de crear una firma que use la clave privada del firmante.

Sub Signfile(ByVal InputFileName As String, _
    ByVal OutputFileName As String)
    
    On Error GoTo ErrorHandler
    Dim c As String
    Dim s As String
    Dim MyStore As New Store
    Dim Signobj As New SignedData
    Dim Signer As New Signer

    ' NOTE: the name 'Attribute' is not a unique name
    ' and must be preceded by 'CAPICOM.'
    Dim SigningTime As New CAPICOM.Attribute

    ' Open the MY store and retrieve the first certificate from the
    ' Store. The signing operation will only work if this
    ' certificate is valid and has access to the signer's private key.
    MyStore.Open CAPICOM_CURRENT_USER_STORE, "MY", _
        CAPICOM_STORE_OPEN_READ_ONLY
    Signer.Certificate = MyStore.Certificates.Item(1)

    ' Open the input file and read the content to be signed from
    ' the file.
    Open App.Path & "\" & InputFileName For Input As #1
    Input #1, c
    Close #1
    
    ' Set the content to be signed.
    Signobj.Content = c

    ' Save the time the data was signed as a signer attribute.
    SigningTime.Name = CAPICOM_AUTHENTICATED_ATTRIBUTE_SIGNING_TIME
    SigningTime.Value = Now
    Signer.AuthenticatedAttributes.Add SigningTime

    ' Sign the content using the signer's private key.
    ' The 'True' parameter indicates that the content signed is not
    ' included in the signature string.
    s = Signobj.Sign(Signer, True)

    Open App.Path & "\" & OutputFileName For Output As #2
    Write #2, s
    Close #2

    MsgBox ("Signature done - Saved to file" & OutputFileName)
    Set Signobj = Nothing
    Set MyStore = Nothing
    Set Signer = Nothing
    Set SigningTime = Nothing

    Exit Sub

ErrorHandler:
    If Err.Number > 0 Then
        MsgBox ("Visual Basic error found:" & Err.Description)
    Else
        MsgBox ("CAPICOM error found : " & Err.Number)
    End If
End Sub

Store.Open

Signer.Certificate

Atributo

SignedData