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 agrega 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 IDigitalSignature interfaz, IDigitalSignatureCollection interfaz y IPresentation.DigitalSignatures propiedad. 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. Abrir el archivo PFX y pasar la contraseña PFX al DigitalSignature objeto.
  2. Agregar la firma creada al objeto de presentación.
using (Presentation pres = new Presentation())
{
    // Crear objeto DigitalSignature con archivo PFX y contraseña PFX 
    DigitalSignature signature = new DigitalSignature("testsignature1.pfx", @"testpass1");

    // Comentar nueva firma digital
    signature.Comments = "Prueba de firma digital de Aspose.Slides.";

    // Agregar firma digital a la presentación
    pres.DigitalSignatures.Add(signature);

    // Guardar presentación
    pres.Save("SomePresentationSigned.pptx", SaveFormat.Pptx);
}

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

// Abrir presentación
using (Presentation pres = new Presentation("SomePresentationSigned.pptx"))
{
    if (pres.DigitalSignatures.Count > 0)
    {
        bool allSignaturesAreValid = true;

        Console.WriteLine("Firmas utilizadas para firmar la presentación: ");

        // Verificar si todas las firmas digitales son válidas
        foreach (DigitalSignature signature in pres.DigitalSignatures)
        {
            Console.WriteLine(signature.Certificate.SubjectName.Name + ", "
                    + signature.SignTime.ToString("yyyy-MM-dd HH:mm") + " -- " + (signature.IsValid ? "VÁLIDA" : "INVALIDA"));
            allSignaturesAreValid &= signature.IsValid;
        }

        if (allSignaturesAreValid)
            Console.WriteLine("La presentación es genuina, todas las firmas son válidas.");
        else
            Console.WriteLine("La presentación ha sido modificada desde la firma.");
    }
}