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 <CipherData>
-Element bei 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 dann wird das XML-Element in eine XML-Datei geschrieben.
#using <System.Xml.dll>
#using <System.Security.dll>
using namespace System;
using namespace System::Xml;
using namespace System::Security::Cryptography;
using namespace System::Security::Cryptography::Xml;
using namespace System::IO;
/// This sample used the EncryptedData class to create a EncryptedData element
/// and write it to an XML file.
int main()
{
// Create a new CipherData object.
CipherData^ cipher = gcnew CipherData();
// Assign a byte array to be the CipherValue. This is a
// byte array representing encrypted data.
cipher->CipherValue = gcnew array<Byte>(8);
// Create a new EncryptedData object.
EncryptedData^ encryptionRoot = gcnew EncryptedData();
//Add an encryption method to the object.
encryptionRoot->Id = "ED";
encryptionRoot->EncryptionMethod = gcnew EncryptionMethod(
"http://www.w3.org/2001/04/xmlenc#aes128-cbc");
encryptionRoot->CipherData = cipher;
//Add key information to the object.
KeyInfo^ keyDetails = gcnew KeyInfo();
keyDetails->AddClause(gcnew KeyInfoRetrievalMethod("#EK",
"http://www.w3.org/2001/04/xmlenc#EncryptedKey"));
encryptionRoot->KeyInfo = keyDetails;
// Create new XML document and put encrypted data into it.
XmlDocument^ doc = gcnew XmlDocument();
XmlElement^ encryptionPropertyElement =
doc->CreateElement("EncryptionProperty",
EncryptedXml::XmlEncNamespaceUrl);
EncryptionProperty^ property = gcnew EncryptionProperty(
encryptionPropertyElement);
encryptionRoot->AddProperty(property);
// Output the resulting XML information into a file.
String^ path = "test.xml";
try
{
File::WriteAllText(path, encryptionRoot->GetXml()->OuterXml);
}
catch (IOException^ ex)
{
Console::WriteLine("There was an error writing to {0}", path);
Console::WriteLine(ex->Message);
}
//Console.WriteLine(ed.GetXml().OuterXml);
}
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 ist 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 enthält, die das <CipherReference>
-Element verwenden.
In vielen Fällen müssen Sie nicht direkt eine neue instance der CipherData -Klasse erstellen. Die EncryptedXmlKlassen , EncryptedDataund EncryptedKey erstellen Instanzen für Sie.
Hinweis
Ein CipherData Objekt kann entweder über eine CipherReference Eigenschaft oder eine CipherValue Eigenschaft verfügen, aber nicht über beides. Ein CryptographicException wird ausgelöst, wenn beide einem CipherData -Objekt zugewiesen sind.
Konstruktoren
CipherData() |
Initialisiert eine neue Instanz der CipherData-Klasse. |
CipherData(Byte[]) |
Initialisiert eine neue Instanz der CipherData-Klasse unter Verwendung eines Bytearrays als CipherValue-Wert. |
CipherData(CipherReference) |
Initialisiert eine neue Instanz der CipherData-Klasse unter Verwendung eines CipherReference-Objekts. |
Eigenschaften
CipherReference |
Ruft das |
CipherValue |
Ruft das |
Methoden
Equals(Object) |
Bestimmt, ob das angegebene Objekt gleich dem aktuellen Objekt ist. (Geerbt von Object) |
GetHashCode() |
Fungiert als Standardhashfunktion. (Geerbt von Object) |
GetType() |
Ruft den 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 des aktuellen Object. (Geerbt von Object) |
ToString() |
Gibt eine Zeichenfolge zurück, die das aktuelle Objekt darstellt. (Geerbt von Object) |