Freigeben über


CipherData Klasse

Definition

Stellt das Element in der <CipherData> XML-Verschlüsselung dar. Diese Klasse kann nicht vererbt werden.

public ref class CipherData sealed
public sealed class CipherData
type CipherData = class
Public NotInheritable Class CipherData
Vererbung
CipherData

Beispiele

Im folgenden Codebeispiel wird die EncryptedData Klasse verwendet, um ein <EncryptedData> Element zu erstellen, das ein <CipherData> Element enthält, und schreibt dann den XML-Code in eine XML-Datei.

using System;
using System.Security.Cryptography.Xml;
using System.Xml;
using System.IO;

/// This sample used the EncryptedData class to create a EncryptedData element
/// and write it to an XML file.
namespace EncryptedDataSample
{
    class Sample1
    {
        [STAThread]
        static void Main(string[] args)
        {
            // Create a new CipherData object.
            CipherData cd = new CipherData();
            // Assign a byte array to be the CipherValue. This is a byte array representing encrypted data.
            cd.CipherValue = new byte[8];
            // Create a new EncryptedData object.
            EncryptedData ed = new EncryptedData();
            //Add an encryption method to the object.
            ed.Id = "ED";
            ed.EncryptionMethod = new EncryptionMethod("http://www.w3.org/2001/04/xmlenc#aes128-cbc");
            ed.CipherData = cd;

            //Add key information to the object.
            KeyInfo ki = new KeyInfo();
            ki.AddClause(new KeyInfoRetrievalMethod("#EK", "http://www.w3.org/2001/04/xmlenc#EncryptedKey"));
            ed.KeyInfo = ki;

            // Create new XML document and put encrypted data into it.
            XmlDocument doc = new XmlDocument();
            XmlElement encryptionPropertyElement = (XmlElement)doc.CreateElement("EncryptionProperty", EncryptedXml.XmlEncNamespaceUrl);
            EncryptionProperty ep = new EncryptionProperty(encryptionPropertyElement);
            ed.AddProperty(ep);

            // Output the resulting XML information into a file.
            string path = @"c:\test\MyTest.xml";
            File.WriteAllText(path,ed.GetXml().OuterXml);
            //Console.WriteLine(ed.GetXml().OuterXml);
        }
    }
}
Imports System.Security.Cryptography.Xml
Imports System.Xml
Imports System.IO


'/ This sample used the EncryptedData class to create a EncryptedData element
'/ and write it to an XML file.
Module EncryptedDataSample1

    Sub Main()
        ' Create a new CipherData object.
        Dim cd As New CipherData
        ' Assign a byte array to the CipherValue.
        cd.CipherValue = New Byte(7) {}
        ' Create a new EncryptedData object.
        Dim ed As New EncryptedData
        'Add an encryption method to the object.
        ed.Id = "ED"
        ed.EncryptionMethod = New EncryptionMethod("http://www.w3.org/2001/04/xmlenc#aes128-cbc")
        ed.CipherData = cd

        'Add key information to the object.
        Dim ki As New KeyInfo
        ki.AddClause(New KeyInfoRetrievalMethod("#EK", "http://www.w3.org/2001/04/xmlenc#EncryptedKey"))
        ed.KeyInfo = ki

        ' Create new XML document and put encrypted data into it.
        Dim doc As New XmlDocument
        Dim encryptionPropertyElement As XmlElement = CType(doc.CreateElement("EncryptionProperty", EncryptedXml.XmlEncNamespaceUrl), XmlElement)
        Dim ep As New EncryptionProperty(encryptionPropertyElement)
        ed.AddProperty(ep)

        ' Output the resulting XML information into a file.
        Dim path As String = "c:\test\MyTest.xml"
        File.WriteAllText(path, ed.GetXml().OuterXml)
        'End Sub
    End Sub

End Module

Hinweise

Die CipherData Klasse stellt das Element in der <CipherData> XML-Verschlüsselung dar. Es handelt sich um ein erforderliches Element, das die verschlüsselten Daten bereitstellt. Sie muss entweder die verschlüsselten Daten als base64-codierter Text des <CipherValue> Elements enthalten oder einen Verweis auf einen externen Speicherort bereitstellen, der die verschlüsselten Daten mit dem <CipherReference> Element enthält.

In vielen Fällen müssen Sie keine neue Instanz der CipherData Klasse direkt erstellen. Die Klassen EncryptedData, und EncryptedKey die EncryptedXmlKlassen erstellen Instanzen für Sie.

Hinweis

Ein CipherData Objekt kann entweder eine CipherReference Eigenschaft oder eine CipherValue Eigenschaft haben, aber nicht beide. Ein CryptographicException Fehler wird ausgelöst, wenn beide einem CipherData Objekt zugewiesen sind.

Konstruktoren

Name Beschreibung
CipherData()

Initialisiert eine neue Instanz der CipherData-Klasse.

CipherData(Byte[])

Initialisiert eine neue Instanz der CipherData Klasse mithilfe eines Bytearrays als CipherValue Wert.

CipherData(CipherReference)

Initialisiert eine neue Instanz der CipherData Klasse mithilfe eines CipherReference Objekts.

Eigenschaften

Name Beschreibung
CipherReference

Ruft das Element ab oder legt es <CipherReference> fest.

CipherValue

Ruft das Element ab oder legt es <CipherValue> fest.

Methoden

Name Beschreibung
Equals(Object)

Bestimmt, ob das angegebene Objekt dem aktuellen Objekt entspricht.

(Geerbt von Object)
GetHashCode()

Dient als Standardhashfunktion.

(Geerbt von Object)
GetType()

Ruft die Type der aktuellen Instanz ab.

(Geerbt von Object)
GetXml()

Ruft die XML-Werte für das CipherData Objekt ab.

LoadXml(XmlElement)

Lädt XML-Daten aus einem XmlElement Objekt in ein CipherData Objekt.

MemberwiseClone()

Erstellt eine flache Kopie der aktuellen Object.

(Geerbt von Object)
ToString()

Gibt eine Zeichenfolge zurück, die das aktuelle Objekt darstellt.

(Geerbt von Object)

Gilt für: