Firma Digital en PowerPoint

Certificado digital se utiliza para crear una presentación de PowerPoint protegida por contraseña, marcada como creada por una organización o persona en particular. El certificado digital se puede obtener contactando a una organización autorizada - una autoridad de certificación. Después de instalar el certificado digital en el sistema, se puede usar para agregar una firma digital a la presentación a través de Archivo -> Información -> Proteger Presentación:

todo:image_alt_text

La presentación puede contener más de una firma digital. Después de que se añade la firma digital a la presentación, aparecerá un mensaje especial en PowerPoint:

todo:image_alt_text

Para firmar la presentación o verificar la autenticidad de las firmas de la presentación, Aspose.Slides API proporciona la interfaz IDigitalSignature, la interfaz IDigitalSignatureCollection y el método IPresentation.getDigitalSignatures . Actualmente, las firmas digitales son compatibles solo con el formato PPTX.

Agregar Firma Digital desde Certificado PFX

El siguiente ejemplo de código demuestra cómo agregar una firma digital desde un certificado PFX:

  1. Abra el archivo PFX y pase la contraseña PFX al objeto DigitalSignature.
  2. Agregue la firma creada al objeto de presentación.
  # Abrir el archivo de presentación
  $pres = new Presentation();
  try {
    # Crear objeto DigitalSignature con archivo PFX y contraseña PFX
    $signature = new DigitalSignature("testsignature1.pfx", "testpass1");
    # Comentar nueva firma digital
    $signature->setComments("Prueba de firma digital de Aspose.Slides.");
    # Agregar firma digital a la presentación
    $pres->getDigitalSignatures()->add($signature);
    # Guardar presentación
    $pres->save("SomePresentationSigned.pptx", SaveFormat::Pptx);
  } finally {
    $pres->dispose();
  }

Ahora es posible verificar si la presentación fue firmada digitalmente y no ha sido modificada:

  # Abrir presentación
  $pres = new Presentation("SomePresentationSigned.pptx");
  try {
    if (java_values($pres->getDigitalSignatures()->size()) > 0) {
      $allSignaturesAreValid = true;
      echo("Firmas utilizadas para firmar la presentación: ");
      # Verificar si todas las firmas digitales son válidas
      foreach($pres->getDigitalSignatures() as $signature) {
        echo($signature->getComments() . ", " . $signature->getSignTime()->toString() . " -- " . $signature->isValid() ? "VÁLIDA" : "INVÁLIDA");
        $allSignaturesAreValid &= $signature->isValid();
      }
      if ($allSignaturesAreValid) {
        echo("La presentación es genuina, todas las firmas son válidas.");
      } else {
        echo("La presentación ha sido modificada desde la firma.");
      }
    }
  } finally {
    if (!java_is_null($pres)) {
      $pres->dispose();
    }
  }