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:
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:
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:
- Abrir el archivo PFX y pasar la contraseña PFX al DigitalSignature objeto.
- 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.");
}
}