Travailler avec les signatures numériques

Une signature numérique est une mise en œuvre technologique de signatures électroniques pour signer des documents et authentifier le signataire pour garantir qu’un document n’a pas été modifié depuis sa signature. Chaque signature numérique est unique pour chaque signataire en raison du respect du protocole de l’ICP pour générer des clés publiques et privées. Signer un document numériquement signifie créer une signature en utilisant la clé privée du signataire où un algorithme mathématique est utilisé pour chiffrer le hash généré.

Aspose.Words vous permet de détecter, de compter ou de vérifier les signatures numériques existantes, ainsi que d’ajouter une nouvelle signature à votre document pour en savoir plus. Vous pouvez également supprimer toutes les signatures numériques d’un document. Utiliser DigitalSignatureUtil cours pour travailler avec des signatures numériques.

Cet article explique comment faire tout ce qui précède pour valider l’authenticité et l’intégrité d’un document numérique.

Formats pris en charge

Aspose.Words vous permet de travailler avec des signatures numériques sur les documents DOC, OOXML et ODT et de signer le document généré en PDF ou XPS modèle.

Limitations des signatures numériques

Le tableau ci-dessous décrit quelques limites auxquelles vous pouvez faire face en travaillant avec des signatures numériques Aspose.Words, ainsi que certaines autres options.

Limitation Autre option
Perte de signatures numériques sur un document après le chargement et l’enregistrement. Par conséquent, le traitement d’un document vers un serveur peut entraîner la perte de toutes les signatures numériques sans préavis Vérifiez si un document a des signatures numériques et prenez les mesures appropriées, le cas échéant. Par exemple, envoyez une alerte aux clients les informant que le document qu’ils téléchargent contient des signatures numériques qui seront perdues si elles sont traitées
Aspose.Words soutient le travail avec les macros dans un document. Mais Aspose.Words ne supporte pas encore les signatures numériques sur les macros Exporter le document vers n’importe quel format Word, et utiliser Microsoft Word pour ajouter une signature numérique aux macros

Détecter, compter et vérifier les signatures numériques

Aspose.Words vous permet de détecter la signature numérique dans un document en utilisant DetectFileFormat méthode et HasDigitalSignature propriété. Il convient de noter qu’un tel contrôle ne permettra de détecter que le fait de la signature, mais pas sa validité.

Un document peut être signé plus d’une fois et cela peut être fait par différents utilisateurs. Pour vérifier la validité des signatures numériques, vous devez les charger à partir du document LoadSignatures et utiliser IsValid propriété. Aussi Aspose.Words vous permet de compter un ensemble de toutes les signatures numériques dans un document en utilisant Count propriété.

Tout cela fournit un moyen efficace et sûr de vérifier un document pour les signatures avant de le traiter.

L’exemple de code suivant montre comment détecter la présence de signatures numériques et les vérifier:

Créer une signature numérique

Pour créer une signature numérique, vous devrez charger un certificat de signature qui confirme l’identité. Lorsque vous envoyez un document signé numériquement, vous envoyez également votre certificat et votre clé publique.

Aspose.Words vous permet de créer un certificat X.509, un certificat numérique qui utilise la norme X.509 ICP acceptée à l’échelle internationale pour vérifier qu’une clé publique appartient au signataire inclus dans le certificat. Pour ce faire, utilisez la Create méthode dans la CertificateHolder En cours.

Les sections suivantes expliquent comment ajouter une signature numérique, une ligne de signature et comment signer un document PDF généré.

Signer un document

Aspose.Words vous permet de signer un document DOC, DOCX ou ODT numériquement en utilisant Sign méthode et SignOptions propriétés.

L’exemple de code suivant montre comment signer les documents à l’aide d’un titulaire de certificat et d’options de signature:

Ajouter une ligne de signature

Une ligne de signature est une représentation visuelle d’une signature numérique dans un document. Aspose.Words vous permet d’insérer une ligne de signature DocumentBuilder.InsertSignatureLine méthode. Vous pouvez également définir les paramètres de cette représentation en utilisant la SignatureLineOptions En cours.

Par exemple, l’image ci-dessous montre comment des signatures valides et non valides peuvent être affichées.

valid-digital-signature invalid-digital-signature

De plus, si un document contient une ligne de signature et aucune signature numérique, il y a une fonction pour demander à l’utilisateur d’ajouter une signature.

L’exemple de code suivant montre comment signer un document avec un certificat personnel et une ligne de signature spécifique:

Signer un document PDF généré

Aspose.Words vous permet de signer et d’obtenir tous les détails d’un document PDF en utilisant PdfDigitalSignatureDetails propriétés.

L’exemple de code suivant montre comment signer un PDF généré:

L’image ci-dessous montre que le document PDF généré est ouvert en Adobe Acrobat et la signature numérique est vérifiée comme présente et valide.

create-digital-signed-pdf-aspose-words-java

Récupérer la valeur de signature numérique

Aspose.Words fournit également la possibilité de récupérer la valeur de signature numérique d’un document signé numériquement comme tableau d’octets en utilisant le SignatureValue propriété.

L’exemple de code suivant montre comment obtenir la valeur de signature numérique comme tableau d’octets d’un document:

Supprimer les signatures numériques

Aspose.Words vous permet de supprimer toutes les signatures numériques d’un document signé RemoveAllSignatures méthode.

L’exemple de code suivant montre comment charger et supprimer les signatures numériques d’un document: