Ajouter des signatures numériques aux présentations en C++
Certificat numérique est utilisé pour créer une présentation PowerPoint protégée par mot de passe, indiquée comme créée par une organisation ou une personne particulière. Le 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 :
Une présentation peut contenir plusieurs signatures numériques. Après qu’une signature numérique a été ajoutée à la présentation, un message spécial apparaît dans PowerPoint :
Pour signer une présentation ou vérifier l’authenticité des signatures de la présentation, l’Aspose.Slides API fournit l’interface IDigitalSignature, l’interface IDigitalSignatureCollection et la méthode IPresentation.DigitalSignatures. Actuellement, les signatures numériques ne sont prises en charge que pour le format PPTX uniquement.
Ajouter une signature numérique à partir d’un certificat PFX
L’exemple de code ci‑dessous montre comment ajouter une signature numérique à partir d’un certificat PFX :
- Ouvrez le fichier PFX et transmettez le mot de passe PFX à l’objet DigitalSignature.
- Ajoutez la signature créée à l’objet présentation.
auto pres = System::MakeObject<Presentation>();
// Créer l'objet DigitalSignature avec le fichier PFX et le mot de passe PFX
auto signature = System::MakeObject<DigitalSignature>(u"testsignature1.pfx", u"testpass1");
// Commenter la nouvelle signature numérique
signature->set_Comments(u"Aspose.Slides digital signing test.");
// Ajouter la signature numérique à la présentation
pres->get_DigitalSignatures()->Add(signature);
// Enregistrer la présentation
pres->Save(u"SomePresentationSigned.pptx", SaveFormat::Pptx);
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
auto pres = System::MakeObject<Presentation>(u"SomePresentationSigned.pptx");
if (pres->get_DigitalSignatures()->get_Count() > 0)
{
bool allSignaturesAreValid = true;
Console::WriteLine(u"Signatures used to sign the presentation: ");
// Vérifier si toutes les signatures numériques sont valides
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"VALID") : System::String(u"INVALID")));
allSignaturesAreValid &= signature->get_IsValid();
}
if (allSignaturesAreValid)
{
Console::WriteLine(u"Presentation is genuine, all signatures are valid.");
}
else
{
Console::WriteLine(u"Presentation has been modified since signing.");
}
}
FAQ
Puis‑je supprimer les signatures existantes d’un fichier ?
Oui. La collection de signatures numériques prend en charge la suppression d’éléments individuels et son vidage complet; après avoir enregistré le fichier, la présentation n’aura aucune signature.
Le fichier devient‑il « lecture seule » après la signature ?
Non. Une signature préserve l’intégrité et la paternité mais ne bloque pas les modifications. Pour restreindre l’édition, combinez‑la avec « lecture seule » ou un mot de passe.
La signature s’affichera‑t‑elle correctement dans différentes versions de PowerPoint ?
La signature est créée pour le conteneur OOXML (PPTX). Les versions récentes de PowerPoint qui prennent en charge les signatures OOXML affichent correctement l’état de ces signatures.