CipherData Klasse
Definition
Wichtig
Einige Informationen beziehen sich auf Vorabversionen, die vor dem Release ggf. grundlegend überarbeitet werden. Microsoft übernimmt hinsichtlich der hier bereitgestellten Informationen keine Gewährleistungen, seien sie ausdrücklich oder konkludent.
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 |
| CipherValue |
Ruft das Element ab oder legt es |
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) |