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 puede obtenerse contactando a una organización autorizada - una autoridad certificadora. Después de instalar el certificado digital en el sistema, se puede utilizar para agregar una firma digital a la presentación a través de Archivo -> Info -> 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 en la presentación, Aspose.Slides API proporciona la interfaz IDigitalSignature, la interfaz IDigitalSignatureCollection y el método IPresentation.DigitalSignatures. 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.
auto pres = System::MakeObject<Presentation>();

// Crear objeto DigitalSignature con archivo PFX y contraseña PFX 
auto signature = System::MakeObject<DigitalSignature>(u"testsignature1.pfx", u"testpass1");

// Comentar nueva firma digital
signature->set_Comments(u"Prueba de firma digital de Aspose.Slides.");

// Agregar firma digital a la presentación
pres->get_DigitalSignatures()->Add(signature);

// Guardar presentación
pres->Save(u"SomePresentationSigned.pptx", SaveFormat::Pptx);

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

// Abrir presentación
auto pres = System::MakeObject<Presentation>(u"SomePresentationSigned.pptx");

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

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

    // Verificar si todas las firmas digitales son válidas
    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"VÁLIDO") : System::String(u"INVALIDO")));
        allSignaturesAreValid &= signature->get_IsValid();
    }

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