Digitale Signaturen zu Präsentationen in PHP hinzufügen

Digital certificate wird verwendet, um eine passwortgeschützte PowerPoint‑Präsentation zu erstellen, die als von einer bestimmten Organisation oder Person erstellt gekennzeichnet ist. Das digitale Zertifikat kann durch Kontaktaufnahme mit einer autorisierten Organisation – einer Zertifizierungsstelle – erhältlich 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 Authentizität von Präsentationssignaturen zu überprüfen, stellt die Aspose.Slides API die Klassen DigitalSignature, die Klasse DigitalSignatureCollection und die Methode Presentation::getDigitalSignatures bereit. 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 eine digitale Signatur aus einem PFX‑Zertifikat hinzugefügt wird:

  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.
  # Öffnen der Präsentationsdatei
  $pres = new Presentation();
  try {
    # DigitalSignature-Objekt mit PFX-Datei und PFX-Passwort erstellen
    $signature = new DigitalSignature("testsignature1.pfx", "testpass1");
    # Kommentar zur neuen digitalen Signatur
    $signature->setComments("Aspose.Slides digital signing test.");
    # Digitale Signatur zur Präsentation hinzufügen
    $pres->getDigitalSignatures()->add($signature);
    # Präsentation speichern
    $pres->save("SomePresentationSigned.pptx", SaveFormat::Pptx);
  } finally {
    $pres->dispose();
  }

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

  # Präsentation öffnen
  $pres = new Presentation("SomePresentationSigned.pptx");
  try {
    if (java_values($pres->getDigitalSignatures()->size()) > 0) {
      $allSignaturesAreValid = true;
      echo("Signatures used to sign the presentation: ");
      # Prüfen, ob alle digitalen Signaturen gültig sind
      foreach($pres->getDigitalSignatures() as $signature) {
        echo($signature->getComments() . ", " . $signature->getSignTime()->toString() . " -- " . $signature->isValid() ? "VALID" : "INVALID");
        $allSignaturesAreValid &= $signature->isValid();
      }
      if ($allSignaturesAreValid) {
        echo("Presentation is genuine, all signatures are valid.");
      } else {
        echo("Presentation has been modified since signing.");
      }
    }
  } finally {
    if (!java_is_null($pres)) {
      $pres->dispose();
    }
  }

FAQ

Kann ich vorhandene Signaturen aus einer Datei entfernen?

Ja. Die Sammlung digitaler Signaturen unterstützt das Entfernen einzelner Elemente und das vollständige 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 die Integrität und Urheberschaft, blockiert jedoch keine Änderungen. Um das Bearbeiten einzuschränken, kombinieren Sie sie mit “Schreibgeschützt” oder ein 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.