Digitale Signaturen zu Präsentationen in C++ hinzufügen

Digitales Zertifikat wird verwendet, um eine passwortgeschützte PowerPoint‑Präsentation zu erstellen, die als von einer bestimmten Organisation oder Person erstellt gekennzeichnet ist. Ein digitales Zertifikat kann durch Kontaktaufnahme mit einer autorisierten Organisation — einer Zertifizierungsstelle — erhalten werden. Nach der Installation des digitalen Zertifikats im System kann es verwendet werden, um der Präsentation über Datei → Info → Präsentation schützen eine digitale Signatur hinzuzufügen:

todo:image_alt_text

Eine Präsentation kann mehr als eine digitale Signatur enthalten. Nachdem die digitale Signatur zur Präsentation hinzugefügt wurde, erscheint in PowerPoint eine spezielle Meldung:

todo:image_alt_text

Um eine Präsentation zu signieren oder die Echtheit von Präsentationssignaturen zu überprüfen, bietet die Aspose.Slides API die Schnittstelle IDigitalSignature, die Schnittstelle IDigitalSignatureCollection und die Methode IPresentation.DigitalSignatures. Derzeit werden digitale Signaturen nur für das PPTX‑Format unterstützt.

Digitale Signatur aus einem PFX‑Zertifikat hinzufügen

Das folgende Codebeispiel zeigt, wie man eine digitale Signatur aus einem PFX‑Zertifikat hinzufügt:

  1. Öffnen Sie die PFX‑Datei und übergeben Sie das PFX‑Passwort an das Objekt DigitalSignature.
  2. Fügen Sie die erstellte Signatur dem Präsentationsobjekt hinzu.
auto pres = System::MakeObject<Presentation>();

// Erstelle DigitalSignature-Objekt mit PFX-Datei und PFX-Passwort 
auto signature = System::MakeObject<DigitalSignature>(u"testsignature1.pfx", u"testpass1");

// Kommentiere neue digitale Signatur
signature->set_Comments(u"Aspose.Slides digital signing test.");

// Füge digitale Signatur zur Präsentation hinzu
pres->get_DigitalSignatures()->Add(signature);

// Speichere Präsentation
pres->Save(u"SomePresentationSigned.pptx", SaveFormat::Pptx);

Jetzt ist es möglich zu prüfen, ob die Präsentation digital signiert wurde und nicht verändert wurde:

// Präsentation öffnen
auto pres = System::MakeObject<Presentation>(u"SomePresentationSigned.pptx");

if (pres->get_DigitalSignatures()->get_Count() > 0)
{
    bool allSignaturesAreValid = true;

    Console::WriteLine(u"Signatures used to sign the presentation: ");

    // Überprüfen, ob alle digitalen Signaturen gültig sind
    for (auto signature : pres->get_DigitalSignatures())
    {
        Console::WriteLine(signature->get_Certificate()->get_SubjectName()->get_Name() 
            + u", " 
            + signature->get_SignTime().ToString(u"yyyy-MM-dd HH:mm") 
            + u" -- " 
            + (signature->get_IsValid() ? System::String(u"VALID") : System::String(u"INVALID")));
        allSignaturesAreValid &= signature->get_IsValid();
    }

    if (allSignaturesAreValid)
    {
        Console::WriteLine(u"Presentation is genuine, all signatures are valid.");
    }
    else
    {
        Console::WriteLine(u"Presentation has been modified since signing.");
    }
}

FAQ

Kann ich vorhandene Signaturen aus einer Datei entfernen?

Ja. Die Sammlung digitaler Signaturen unterstützt das Entfernen einzelner Elemente und das komplette Leeren; nachdem Sie die Datei gespeichert haben, enthält die Präsentation keine Signaturen mehr.

Wird die Datei nach dem Signieren “schreibgeschützt”?

Nein. Eine Signatur bewahrt Integrität und Urheberschaft, blockiert jedoch keine Änderungen. Um das Bearbeiten zu beschränken, kombinieren Sie sie mit “Read-only” oder einem Passwort.

Wird die Signatur in verschiedenen PowerPoint-Versionen korrekt angezeigt?

Die Signatur wird für den OOXML‑(PPTX‑)Container erstellt. Moderne PowerPoint‑Versionen, die OOXML‑Signaturen unterstützen, zeigen den Status solcher Signaturen korrekt an.