Signature numérique dans PowerPoint

Certificat numérique est utilisé pour créer une présentation powerpoint protégée par mot de passe, marquée comme créée par une organisation ou une personne particulière. Un certificat numérique peut être obtenu en contactant une organisation autorisée - une autorité de certification. Après avoir installé le certificat numérique dans le système, il peut être utilisé pour ajouter une signature numérique à la présentation via Fichier -> Informations -> Protéger la présentation :

todo:image_alt_text

La présentation peut contenir plus d’une signature numérique. Après qu’une signature numérique a été ajoutée à la présentation, un message spécial apparaîtra dans PowerPoint :

todo:image_alt_text

Pour signer la présentation ou vérifier l’authenticité des signatures de présentation, l'API Aspose.Slides fournit l’interface IDigitalSignature, l’interface IDigitalSignatureCollection et la méthode IPresentation.getDigitalSignatures. Actuellement, les signatures numériques ne sont supportées que pour le format PPTX.

Ajouter une signature numérique à partir d’un certificat PFX

L’exemple de code ci-dessous démontre comment ajouter une signature numérique à partir d’un certificat PFX :

  1. Ouvrir le fichier PFX et passer le mot de passe PFX à l’objet DigitalSignature.
  2. Ajouter la signature créée à l’objet présentation.
  # Ouverture du fichier de présentation
  $pres = new Presentation();
  try {
    # Créer un objet DigitalSignature avec le fichier PFX et le mot de passe PFX
    $signature = new DigitalSignature("testsignature1.pfx", "testpass1");
    # Commenter la nouvelle signature numérique
    $signature->setComments("Test de signature numérique Aspose.Slides.");
    # Ajouter la signature numérique à la présentation
    $pres->getDigitalSignatures()->add($signature);
    # Sauvegarder la présentation
    $pres->save("SomePresentationSigned.pptx", SaveFormat::Pptx);
  } finally {
    $pres->dispose();
  }

Il est maintenant possible de vérifier si la présentation a été signée numériquement et n’a pas été modifiée :

  # Ouvrir la présentation
  $pres = new Presentation("SomePresentationSigned.pptx");
  try {
    if (java_values($pres->getDigitalSignatures()->size()) > 0) {
      $allSignaturesAreValid = true;
      echo("Signatures utilisées pour signer la présentation : ");
      # Vérifier si toutes les signatures numériques sont valides
      foreach($pres->getDigitalSignatures() as $signature) {
        echo($signature->getComments() . ", " . $signature->getSignTime()->toString() . " -- " . $signature->isValid() ? "VALID" : "INVALID");
        $allSignaturesAreValid &= $signature->isValid();
      }
      if ($allSignaturesAreValid) {
        echo("La présentation est authentique, toutes les signatures sont valides.");
      } else {
        echo("La présentation a été modifiée depuis la signature.");
      }
    }
  } finally {
    if (!java_is_null($pres)) {
      $pres->dispose();
    }
  }