עבודה עם חתימה דיגיטלית

חתימה דיגיטלית היא יישום טכנולוגי של חתימות אלקטרוניות לחתום על מסמכים ולאמת את השלט כדי להבטיח כי מסמך לא השתנה מאז החתימה. כל חתימה דיגיטלית היא ייחודית עבור כל אחד מהחתמים בגלל ביצוע פרוטוקול PKI כדי ליצור הן מפתחות ציבוריים ופרטיים. לחתום על מסמך דיגיטלי פירושו ליצור חתימה באמצעות המפתח הפרטי של חותם שבו אלגוריתם מתמטי משמש כדי להצפין את הישבן שנוצר.

Aspose.Words מאפשר לך לזהות, לספור, או לאמת את החתימות הדיגיטליות הקיימות, וגם להוסיף חתימה חדשה למסמך שלך כדי לברר כל tampering בו. ניתן גם להסיר את כל החתימות הדיגיטליות מתוך מסמך. השתמש DigitalSignatureUtil לעבוד עם חתימות דיגיטליות.

מאמר זה מסביר כיצד לעשות את כל האמור לעיל כדי לאמת את האותנטיות והשלמות של מסמך דיגיטלי.

פורמטים תומכים

Aspose.Words מאפשר לך לעבוד עם חתימות דיגיטליות על מסמכי DOC, OOXML ו- ODT ולחתום על המסמך שנוצר ב- PDF או PDF. XPS פורמט.

מגבלות של חתימה דיגיטלית

הטבלה להלן מתארת כמה מגבלות שניתן להתמודד איתן תוך כדי עבודה עם חתימה דיגיטלית דרך Aspose.Words, כמו גם כמה אפשרויות חלופיות.

הגבלת אפשרות חלופית
אובדן חתימות דיגיטליות על מסמך לאחר טעינה והצלתו. לכן, עיבוד מסמך לשרת עלול לגרום לאובדן כל החתימות הדיגיטליות ללא הודעה בדוק אם מסמך יש חתימה דיגיטלית ולבצע את הפעולה המתאימה אם יימצאו. לדוגמה, לשלוח התראה ללקוחות להודיע להם כי המסמך שהם מעלים מכיל חתימות דיגיטליות שאבדו אם הוא מעובד
Aspose.Words תומך בעבודה עם מאקרו במסמך. אבל Aspose.Words עדיין לא תומך בחתימות דיגיטליות על מאקרו מייצא את המסמך בחזרה לכל פורמט Word, ולהשתמש Microsoft Word להוסיף חתימה דיגיטלית למאקרו

Detect, Count ובדוק חתימות דיגיטליות

Aspose.Words מאפשר לך לזהות חתימה דיגיטלית במסמך באמצעות DetectFileFormat השיטה וה HasDigitalSignature רכוש. ראוי לציין כי בדיקה כזו רק תזהה את עובדת החתימה, אך לא את תוקפה.

ניתן לחתום על מסמך יותר מפעם אחת, וזה יכול להיעשות על ידי משתמשים שונים. כדי לבדוק את תוקף החתימות הדיגיטליות, עליך לטעון אותן מן המסמך באמצעות המסמך. LoadSignatures שיטה ושימוש IsValid רכוש. גם Aspose.Words מאפשר לך לספור קבוצה של כל החתימות הדיגיטליות בתוך מסמך באמצעות המסמך. Count רכוש.

כל זה מספק דרך יעילה ובטוחה לבדוק מסמך לחתימות לפני עיבודו.

הדוגמה הבאה של הקוד מראה כיצד לזהות את נוכחותן של חתימות דיגיטליות ולאמת אותם:

// 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 + ");
}

ליצור חתימה דיגיטלית

כדי ליצור חתימה דיגיטלית, עליך לטעון תעודה חתימה המאשרת זהות. כאשר אתה שולח מסמך חתום דיגיטלית, אתה גם שולח את האישור שלך ואת המפתח הציבורי.

Aspose.Words מאפשר לך ליצור תעודת X.509, תעודה דיגיטלית המשתמשת תקן X.509 PKI המקובל בעולם כדי לוודא כי מפתח ציבורי שייך לסימן הכלול בתוך האישור. לעשות זאת, השתמש Create בתוך השיטה CertificateHolder מעמד.

הקטעים הבאים מסבירים כיצד להוסיף חתימה דיגיטלית, קו חתימה וכיצד לחתום על מסמך PDF שנוצר.

לחתום על מסמך

Aspose.Words מאפשר לך לחתום על DOC, DOCX, או ODT לתעד דיגיטלית באמצעות ה- ODT. Sign שיטה ו SignOptions תכונות.

הדוגמה הבאה של הקוד מראה כיצד לחתום על מסמכים באמצעות בעל תעודה ואפשרויות כניסה:

// 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);

הוסף קו חתימה

קו חתימה הוא ייצוג חזותי של חתימה דיגיטלית במסמך. Aspose.Words מאפשר לך להוסיף קו חתימה באמצעות DocumentBuilder.InsertSignatureLine שיטה. אתה יכול גם להגדיר את הפרמטרים עבור ייצוג זה באמצעות SignatureLineOptions מעמד.

לדוגמה, התמונה למטה מראה כיצד ניתן להציג חתימות תקפות ולא יסולא.

valid-digital-signature invalid-digital-signature

כמו כן, אם מסמך מכיל קו חתימה ואין חתימה דיגיטלית, יש תכונה לבקש מהמשתמש להוסיף חתימה.

הדוגמה הבאה של הקוד מראה כיצד לחתום על מסמך עם תעודה אישית ושורה חתימה ספציפית:

// 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);

מסמך PDF שנוצר

Aspose.Words מאפשר לך לחתום ולקבל את כל הפרטים של מסמך PDF באמצעות מסמך PDF PdfDigitalSignatureDetails תכונות.

לדוגמה הקוד הבא מראה כיצד לחתום על PDF שנוצר:

// 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);

התמונה להלן מראה כי מסמך PDF שנוצר נפתח בתוך Adobe Acrobat והחתימה הדיגיטלית מאומתת כנוכחת ומתאימות.

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

להעריך מחדש את ערך החתימה הדיגיטלי

Aspose.Words כמו כן, מספק את היכולת לשחזר את ערך החתימה הדיגיטלי מ מסמך חתום דיגיטלית כמערך ע"י ע"י שימוש במערך ע"י שימוש. SignatureValue רכוש.

הדוגמה הבאה של הקוד מראה כיצד להשיג את ערך החתימה הדיגיטלי כמערך עוטה של מסמך:

// 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);
}

להסיר חתימות דיגיטליות

Aspose.Words מאפשר להסיר את כל החתימות הדיגיטליות מ מסמך חתום תוך שימוש RemoveAllSignatures שיטה.

לדוגמה הקוד הבא מראה כיצד לטעון ולהסיר חתימות דיגיטליות ממסמכים:

// 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);