Arbeiten mit digitalen Signaturen
Eine digitale Signatur ist eine technologische Implementierung elektronischer Signaturen zum Signieren von Dokumenten und zur Authentifizierung des Unterzeichners, um sicherzustellen, dass ein Dokument seit seiner Unterzeichnung nicht geändert wurde. Jede digitale Signatur ist für jeden Unterzeichner eindeutig, da das PKI -Protokoll befolgt wird, um sowohl öffentliche als auch private Schlüssel zu generieren. Ein Dokument digital signieren bedeutet, eine Signatur mit dem privaten Schlüssel des Unterzeichners zu erstellen, wobei ein mathematischer Algorithmus verwendet wird, um den generierten Hash zu verschlüsseln.
Aspose.Words ermöglicht es Ihnen, vorhandene digitale Signaturen zu erkennen, zu zählen oder zu verifizieren sowie Ihrem Dokument eine neue Signatur hinzuzufügen, um Manipulationen festzustellen. Sie können auch alle digitalen Signaturen aus einem Dokument entfernen. Verwenden Sie die Klasse DigitalSignatureUtil, um mit digitalen Signaturen zu arbeiten.
In diesem Artikel wird erläutert, wie Sie alle oben genannten Schritte ausführen, um die Authentizität und Integrität eines digitalen Dokuments zu überprüfen.
Online ausprobieren
Sie können diese Funktionalität mit unserem ausprobieren Kostenlose Online Signatur.
Unterstützte Formate
Mit Aspose.Words können Sie mit digitalen Signaturen für DOC-, OOXML- und ODT-Dokumente arbeiten und das generierte Dokument im Format PDF oder XPS signieren.
Einschränkungen digitaler Signaturen
In der folgenden Tabelle werden einige Einschränkungen beschrieben, die bei der Arbeit mit digitalen Signaturen über Aspose.Words auftreten können, sowie einige alternative Optionen.
Einschränkung | Alternative Option |
---|---|
Verlust von digitalen Signaturen auf einem Dokument nach dem Laden und Speichern. Daher kann die Verarbeitung eines Dokuments auf einem Server zum Verlust aller digitalen Signaturen ohne Vorankündigung führen. | Überprüfen Sie, ob ein Dokument über digitale Signaturen verfügt, und ergreifen Sie gegebenenfalls die entsprechenden Maßnahmen. Senden Sie beispielsweise eine Warnung an die Kunden, in der sie darüber informiert werden, dass das hochgeladene Dokument digitale Signaturen enthält, die bei der Verarbeitung verloren gehen. |
Aspose.Words unterstützt die Arbeit mit Makros in einem Dokument. Aspose.Words unterstützt jedoch noch keine digitalen Signaturen auf Makros. | Exportieren Sie das Dokument zurück in ein beliebiges Word-Format und fügen Sie Makros mit Microsoft Word eine digitale Signatur hinzu. |
Digitale Signaturen erkennen, zählen und verifizieren
Aspose.Words ermöglicht es Ihnen, digitale Signaturen in einem Dokument mithilfe der DetectFileFormat-Methode und der HasDigitalSignature-Eigenschaft zu erkennen. Es ist anzumerken, dass eine solche Überprüfung nur die Tatsache der Unterschrift, nicht aber ihre Gültigkeit erkennt.
Ein Dokument kann mehrmals signiert werden, und dies kann von verschiedenen Benutzern durchgeführt werden. Um die Gültigkeit digitaler Signaturen zu überprüfen, müssen Sie sie mit der Methode LoadSignatures aus dem Dokument laden und die Eigenschaft IsValid verwenden. Außerdem können Sie mit Aspose.Words einen Satz aller digitalen Signaturen in einem Dokument mithilfe der Eigenschaft Count zählen.
All dies bietet eine effiziente und sichere Möglichkeit, ein Dokument vor der Verarbeitung auf Signaturen zu überprüfen.
Das folgende Codebeispiel zeigt, wie Sie das Vorhandensein digitaler Signaturen erkennen und überprüfen können:
// For complete examples and data files, please go to https://github.com/aspose-words/Aspose.Words-for-Java.git. | |
FileFormatInfo info = FileFormatUtil.detectFileFormat(getMyDir() + "Digitally signed.docx"); | |
if (info.hasDigitalSignature()) | |
{ | |
System.out.println("Document {Path.GetFileName(MyDir + "); | |
} |
Erstellen einer digitalen Signatur
Um eine digitale Signatur zu erstellen, müssen Sie ein Signaturzertifikat laden, das die Identität bestätigt. Wenn Sie ein digital signiertes Dokument senden, senden Sie auch Ihr Zertifikat und Ihren öffentlichen Schlüssel.
Mit Aspose.Words können Sie ein X.509-Zertifikat erstellen, ein digitales Zertifikat, das den international anerkannten X.509 PKI -Standard verwendet, um zu überprüfen, ob ein öffentlicher Schlüssel dem im Zertifikat enthaltenen Unterzeichner gehört. Verwenden Sie dazu die Methode Create innerhalb der Klasse CertificateHolder.
In den nächsten Abschnitten wird erläutert, wie Sie eine digitale Signatur, eine Signaturzeile und ein generiertes PDF-Dokument signieren.
Ein Dokument signieren
Mit Aspose.Words können Sie ein DOC-, DOCX- oder ODT-Dokument digital mit der Sign-Methode und den SignOptions-Eigenschaften signieren.
Das folgende Codebeispiel zeigt, wie Dokumente mit einem Zertifikatsinhaber und Signaturoptionen signiert werden:
// For complete examples and data files, please go to https://github.com/aspose-words/Aspose.Words-for-Java.git. | |
CertificateHolder certHolder = CertificateHolder.create(getMyDir() + "morzal.pfx", "aw"); | |
DigitalSignatureUtil.sign(getMyDir() + "Digitally signed.docx", getArtifactsDir() + "Document.Signed.docx", | |
certHolder); |
Fügen Sie eine Signaturzeile hinzu
Eine Signaturzeile ist eine visuelle Darstellung einer digitalen Signatur in einem Dokument. Mit Aspose.Words können Sie eine Signaturzeile mit der Methode DocumentBuilder.InsertSignatureLine einfügen. Sie können die Parameter für diese Darstellung auch mit der Klasse SignatureLineOptions festlegen.
Das folgende Bild zeigt beispielsweise, wie gültige und ungültige Signaturen angezeigt werden können.
Wenn ein Dokument eine Signaturzeile und keine digitale Signatur enthält, gibt es auch eine Funktion, mit der der Benutzer aufgefordert wird, eine Signatur hinzuzufügen.
Das folgende Codebeispiel zeigt, wie Sie ein Dokument mit einem persönlichen Zertifikat und einer bestimmten Signaturzeile signieren:
// For complete examples and data files, please go to https://github.com/aspose-words/Aspose.Words-for-Java.git. | |
Document doc = new Document(); | |
DocumentBuilder builder = new DocumentBuilder(doc); | |
SignatureLineOptions signatureLineOptions = new SignatureLineOptions(); | |
{ | |
signatureLineOptions.setSigner("yourname"); | |
signatureLineOptions.setSignerTitle("Worker"); | |
signatureLineOptions.setEmail("yourname@aspose.com"); | |
signatureLineOptions.setShowDate(true); | |
signatureLineOptions.setDefaultInstructions(false); | |
signatureLineOptions.setInstructions("Please sign here."); | |
signatureLineOptions.setAllowComments(true); | |
} | |
SignatureLine signatureLine = builder.insertSignatureLine(signatureLineOptions).getSignatureLine(); | |
signatureLine.setProviderId(UUID.fromString("CF5A7BB4-8F3C-4756-9DF6-BEF7F13259A2")); | |
doc.save(getArtifactsDir() + "SignDocuments.SignatureLineProviderId.docx"); | |
SignOptions signOptions = new SignOptions(); | |
{ | |
signOptions.setSignatureLineId(signatureLine.getId()); | |
signOptions.setProviderId(signatureLine.getProviderId()); | |
signOptions.setComments("Document was signed by Aspose"); | |
signOptions.setSignTime(new Date()); | |
} | |
CertificateHolder certHolder = CertificateHolder.create(getMyDir() + "morzal.pfx", "aw"); | |
DigitalSignatureUtil.sign(getArtifactsDir() + "SignDocuments.SignatureLineProviderId.docx", | |
getArtifactsDir() + "SignDocuments.CreateNewSignatureLineAndSetProviderId.docx", certHolder, signOptions); |
Signieren eines generierten PDF Dokuments
Aspose.Words ermöglicht das Signieren und Abrufen aller Details eines PDF-Dokuments mithilfe der PdfDigitalSignatureDetails-Eigenschaften.
Das folgende Codebeispiel zeigt, wie eine generierte PDF signiert wird:
// For complete examples and data files, please go to https://github.com/aspose-words/Aspose.Words-for-Java.git. | |
Document doc = new Document(); | |
DocumentBuilder builder = new DocumentBuilder(doc); | |
builder.writeln("Test Signed PDF."); | |
PdfSaveOptions saveOptions = new PdfSaveOptions(); | |
{ | |
saveOptions.setDigitalSignatureDetails(new PdfDigitalSignatureDetails( | |
CertificateHolder.create(getMyDir() + "morzal.pfx", "aw"), "reason", "location", | |
new Date())); | |
} | |
doc.save(getArtifactsDir() + "WorkingWithPdfSaveOptions.DigitallySignedPdfUsingCertificateHolder.pdf", saveOptions); |
Das folgende Bild zeigt, dass das generierte PDF -Dokument in Adobe Acrobat geöffnet und die digitale Signatur als vorhanden und gültig verifiziert wird.
Abrufen des Werts der digitalen Signatur
Aspose.Words bietet auch die Möglichkeit, den digitalen Signaturwert aus einem digital signierten Dokument als Byte-Array mit der Eigenschaft SignatureValue abzurufen.
Das folgende Codebeispiel zeigt, wie Sie den Wert der digitalen Signatur als Byte-Array aus einem Dokument abrufen:
// For complete examples and data files, please go to https://github.com/aspose-words/Aspose.Words-for-Java.git. | |
Document doc = new Document(getMyDir() + "Digitally signed.docx"); | |
for (DigitalSignature digitalSignature : doc.getDigitalSignatures()) | |
{ | |
String signatureValue = Base64.getEncoder().encodeToString(digitalSignature.getSignatureValue()); | |
Assert.assertEquals("K1cVLLg2kbJRAzT5WK+m++G8eEO+l7S+5ENdjMxxTXkFzGUfvwxREuJdSFj9AbD" + | |
"MhnGvDURv9KEhC25DDF1al8NRVR71TF3CjHVZXpYu7edQS5/yLw/k5CiFZzCp1+MmhOdYPcVO+Fm" + | |
"+9fKr2iNLeyYB+fgEeZHfTqTFM2WwAqo=", signatureValue); | |
} |
Digitale Signaturen entfernen
Mit Aspose.Words können Sie alle digitalen Signaturen mit der RemoveAllSignatures-Methode aus einem signierten Dokument entfernen.
Das folgende Codebeispiel zeigt, wie Sie digitale Signaturen aus einem Dokument laden und entfernen:
// For complete examples and data files, please go to https://github.com/aspose-words/Aspose.Words-for-Java.git. | |
// There are two ways of using the DigitalSignatureUtil class to remove digital signatures | |
// from a signed document by saving an unsigned copy of it somewhere else in the local file system. | |
// 1 - Determine the locations of both the signed document and the unsigned copy by filename strings: | |
DigitalSignatureUtil.removeAllSignatures(getMyDir() + "Digitally signed.docx", | |
getArtifactsDir() + "DigitalSignatureUtil.LoadAndRemove.FromString.docx"); | |
// 2 - Determine the locations of both the signed document and the unsigned copy by file streams: | |
try (FileInputStream streamIn = new FileInputStream(getMyDir() + "Digitally signed.docx")) | |
{ | |
try (FileOutputStream streamOut = new FileOutputStream(getArtifactsDir() + "DigitalSignatureUtil.LoadAndRemove.FromStream.docx")) | |
{ | |
DigitalSignatureUtil.removeAllSignatures(streamIn, streamOut); | |
} | |
} | |
// Verify that both our output documents have no digital signatures. | |
Assert.assertEquals(IterableUtils.size(DigitalSignatureUtil.loadSignatures(getArtifactsDir() + "DigitalSignatureUtil.LoadAndRemove.FromString.docx")), 0); | |
Assert.assertEquals(IterableUtils.size(DigitalSignatureUtil.loadSignatures(getArtifactsDir() + "DigitalSignatureUtil.LoadAndRemove.FromStream.docx")), 0); |