DigitalSignatureUtil

DigitalSignatureUtil class

Fournit des méthodes pour signer un document.

Pour en savoir plus, visitez leTravailler avec des signatures numériques article documentaire.

public static class DigitalSignatureUtil

Méthodes

NomLa description
static LoadSignatures(Stream)Charge les signatures numériques du document à l’aide de stream.
static LoadSignatures(string)Charge les signatures numériques du document.
static RemoveAllSignatures(Stream, Stream)Supprime toutes les signatures numériques du document dans le flux source et écrit le document non signé dans le flux de destination.
static RemoveAllSignatures(string, string)Supprime toutes les signatures numériques du fichier source et écrit le fichier non signé dans le fichier de destination.
static Sign(Stream, Stream, CertificateHolder)Signe le document source en utilisant ce qui est donnéCertificateHolderavec signature numérique et écrit le document signé dans le flux de destination.
static Sign(string, string, CertificateHolder)Signe le document source en utilisant ce qui est donnéCertificateHolder avec signature numérique et écrit le document signé dans le fichier de destination.
static Sign(Stream, Stream, CertificateHolderSignOptions)Signe le document source en utilisant ce qui est donnéCertificateHolder etSignOptions avec signature numérique et écrit le document signé dans le flux de destination.
static Sign(string, string, CertificateHolderSignOptions)Signe le document source en utilisant ce qui est donnéCertificateHolder etSignOptions avec signature numérique et écrit le document signé dans le fichier de destination.

Remarques

Étant donné que la signature numérique fonctionne avec le contenu du fichier plutôt qu’avec le modèle objet de document, ces méthodes sont placées dans une classe distincte.

Les formats pris en charge sontDoc etDocx.

Exemples

Montre comment charger des signatures à partir d’un document signé numériquement.

// Il existe deux manières de charger la collection de signatures numériques d'un document signé à l'aide de la classe DigitalSignatureUtil.
// 1 - Chargement à partir d'un document à partir d'un nom de fichier du système de fichiers local :
DigitalSignatureCollection digitalSignatures = 
    DigitalSignatureUtil.LoadSignatures(MyDir + "Digitally signed.docx");

// Si cette collection n'est pas vide, alors nous pouvons vérifier que le document est signé numériquement.
Assert.AreEqual(1, digitalSignatures.Count);

// 2 - Chargement depuis un document depuis un FileStream :
using (Stream stream = new FileStream(MyDir + "Digitally signed.docx", FileMode.Open))
{
    digitalSignatures = DigitalSignatureUtil.LoadSignatures(stream);
    Assert.AreEqual(1, digitalSignatures.Count);
}

Montre comment supprimer les signatures numériques d’un document signé numériquement.

// Il existe deux manières d'utiliser la classe DigitalSignatureUtil pour supprimer les signatures numériques
// à partir d'un document signé en enregistrant une copie non signée de celui-ci ailleurs dans le système de fichiers local.
// 1 - Déterminez les emplacements du document signé et de la copie non signée par les chaînes de nom de fichier :
DigitalSignatureUtil.RemoveAllSignatures(MyDir + "Digitally signed.docx",
    ArtifactsDir + "DigitalSignatureUtil.LoadAndRemove.FromString.docx");

// 2 - Déterminez les emplacements du document signé et de la copie non signée par flux de fichiers :
using (Stream streamIn = new FileStream(MyDir + "Digitally signed.docx", FileMode.Open))
{
    using (Stream streamOut = new FileStream(ArtifactsDir + "DigitalSignatureUtil.LoadAndRemove.FromStream.docx", FileMode.Create))
    {
        DigitalSignatureUtil.RemoveAllSignatures(streamIn, streamOut);
    }
}

// Vérifiez que nos deux documents de sortie n'ont pas de signature numérique.
Assert.That(DigitalSignatureUtil.LoadSignatures(ArtifactsDir + "DigitalSignatureUtil.LoadAndRemove.FromString.docx"), Is.Empty);
Assert.That(DigitalSignatureUtil.LoadSignatures(ArtifactsDir + "DigitalSignatureUtil.LoadAndRemove.FromStream.docx"), Is.Empty);

Voir également