Condividi tramite


CipherReference Classe

Definizione

Rappresenta l'elemento <CipherReference> nella crittografia XML. La classe non può essere ereditata.

public ref class CipherReference sealed : System::Security::Cryptography::Xml::EncryptedReference
public sealed class CipherReference : System.Security.Cryptography.Xml.EncryptedReference
type CipherReference = class
    inherit EncryptedReference
Public NotInheritable Class CipherReference
Inherits EncryptedReference
Ereditarietà
CipherReference

Esempio

Nell'esempio di codice seguente viene creata una nuova istanza di CipherReference.

#using <System.Xml.dll>
#using <System.Security.dll>
#using <System.dll>

using namespace System;
using namespace System::Security::Cryptography::Xml;
using namespace System::Xml;
using namespace System::IO;

/// This sample used the EncryptedData class to create an encrypted data element
/// and write it to an XML file. It demonstrates the use of CipherReference.

[STAThread]
int main()
{
   
   //Create a URI string.
   String^ uri = "http://www.woodgrovebank.com/document.xml";
   
   // Create a Base64 transform. The input content retrieved from the
   // URI should be Base64-decoded before other processing.
   Transform^ base64 = gcnew XmlDsigBase64Transform;
   
   //Create a transform chain and add the transform to it.
   TransformChain^ tc = gcnew TransformChain;
   tc->Add( base64 );
   
   //Create <CipherReference> information.
   CipherReference ^ reference = gcnew CipherReference( uri,tc );
   
   // Create a new CipherData object using the CipherReference information.
   // Note that you cannot assign both a CipherReference and a CipherValue
   // to a CipherData object.
   CipherData ^ cd = gcnew CipherData( reference );
   
   // Create a new EncryptedData object.
   EncryptedData^ ed = gcnew EncryptedData;
   
   //Add an encryption method to the object.
   ed->Id = "ED";
   ed->EncryptionMethod = gcnew EncryptionMethod( "http://www.w3.org/2001/04/xmlenc#aes128-cbc" );
   ed->CipherData = cd;
   
   //Add key information to the object.
   KeyInfo^ ki = gcnew KeyInfo;
   ki->AddClause( gcnew 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 = gcnew XmlDocument;
   XmlElement^ encryptionPropertyElement = dynamic_cast<XmlElement^>(doc->CreateElement( "EncryptionProperty", EncryptedXml::XmlEncNamespaceUrl ));
   EncryptionProperty ^ ep = gcnew EncryptionProperty( encryptionPropertyElement );
   ed->AddProperty( ep );
   
   // Output the resulting XML information into a file.
   try
   {
      String^ path = "c:\\test\\MyTest.xml";
      File::WriteAllText( path, ed->GetXml()->OuterXml );
   }
   catch ( IOException^ e ) 
   {
      Console::WriteLine( "File IO error. {0}", e );
   }

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

/// This sample used the EncryptedData class to create an encrypted data element
/// and write it to an XML file. It demonstrates the use of CipherReference.
namespace EncryptedDataSample
{
    class Example
    {
        [STAThread]
        static void Main(string[] args)
        {
            //Create a URI string.
            String uri = "http://www.woodgrovebank.com/document.xml";
            // Create a Base64 transform. The input content retrieved from the
            // URI should be Base64-decoded before other processing.
            Transform base64 = new XmlDsigBase64Transform();
            //Create a transform chain and add the transform to it.
            TransformChain tc = new TransformChain();
            tc.Add(base64);
            //Create <CipherReference> information.
            CipherReference reference = new CipherReference(uri, tc);

            // Create a new CipherData object using the CipherReference information.
            // Note that you cannot assign both a CipherReference and a CipherValue
            // to a CipherData object.
            CipherData cd = new CipherData(reference);

            // 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.
            try
            {
                string path = @"c:\test\MyTest.xml";

                File.WriteAllText(path, ed.GetXml().OuterXml);
            }
            catch (IOException e)
            {
                Console.WriteLine("File IO error. {0}", e);
            }
        }
    }
}
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. It demonstrates the use of CipherReference.
Module Module1

    Sub Main()
        ' Create a URI string.
        Dim uri As String = "http://www.woodgrovebank.com/document.xml"
        ' Create a Base64 transform. The input content retrieved from the
        ' URI should be Base64-decoded before other processing.
        Dim base64 As Transform = New XmlDsigBase64Transform
        Dim tc As New TransformChain
        tc.Add(base64)
        ' Create <CipherReference> information.
        Dim reference As CipherReference = New CipherReference(uri, tc)

        ' Create a new CipherData object.
        ' Note that you cannot assign both a CipherReference and a CipherValue
        ' to a CipherData object.
        Dim cd As CipherData = New CipherData(Reference)

        ' 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 Module

Commenti

Questa classe rappresenta l'elemento <CipherReference> nella crittografia XML. Identifica un'origine che, quando elaborata, restituisce i dati crittografati.

I dati crittografati effettivi a cui fa riferimento l'oggetto <CipherReference> vengono ottenuti dal processo seguente. La <CipherReference> URI proprietà contiene un URI (Uniform Resource Identifier) dereferenziato. Se l'elemento <CipherReference> contiene anche una catena di trasformazione, i dati risultanti dalla dereferenziazione dell'URI vengono trasformati come specificato per produrre i dati crittografati. Ad esempio, se i dati crittografati sono codificati in base64 all'interno di un documento XML, le trasformazioni specificano un'espressione XPath seguita da una decodifica base64 in modo che i dati crittografati possano essere estratti.

La sintassi dell'URI e delle trasformazioni è simile a quella delle firme digitali XML. Nelle firme digitali XML, tuttavia, l'elaborazione della generazione e della convalida inizia con gli stessi dati di origine ed esegue tale trasformazione nello stesso ordine. Nella crittografia XML l'applicazione di decrittografia include solo i dati crittografati e le trasformazioni specificate. Le trasformazioni vengono enumerate nell'ordine necessario per ottenere i dati crittografati.

Nota Per impostazione predefinita, non è possibile dereferenziare i riferimenti di crittografia da documenti con origini sconosciute, ad esempio i file di un sito Web, perché la DocumentEvidence proprietà è Null. Ad esempio, quando si tenta di decrittografare un file contenente un <CipherReference> elemento che fa riferimento a un file sul Web, viene generata un'eccezione SecurityException , anche se la richiesta viene effettuata da un assembly completamente attendibile.

Se si è certi che i documenti che si stanno decrittografando possono essere considerati attendibili, è possibile modificare questo comportamento per le applicazioni completamente attendibili usando il codice seguente:

Evidence ev = new Evidence();  
ev.AddHost (new Zone(SecurityZone.MyComputer));  
EncryptedXml exml = new EncryptedXml(doc, ev);  

Costruttori

CipherReference()

Inizializza una nuova istanza della classe CipherReference.

CipherReference(String)

Consente di inizializzare una nuova istanza della classe CipherReference utilizzando l'URI (Uniform Resource Identifier) specificato.

CipherReference(String, TransformChain)

Inizializza una nuova istanza della classe CipherReference utilizzando l'URI (Uniform Resource Identifier) e le informazioni sulla catena di trasformazioni.

Proprietà

CacheValid

Ottiene un valore che indica se la cache è valida.

(Ereditato da EncryptedReference)
ReferenceType

Ottiene o imposta il tipo di riferimento.

(Ereditato da EncryptedReference)
TransformChain

Ottiene o imposta la catena delle trasformazioni di un oggetto EncryptedReference.

(Ereditato da EncryptedReference)
Uri

Ottiene o imposta l'URI (Uniform Resource Identifier) di un oggetto EncryptedReference.

(Ereditato da EncryptedReference)

Metodi

AddTransform(Transform)

Consente di aggiungere un oggetto Transform alla catena di trasformazioni corrente di un oggetto EncryptedReference.

(Ereditato da EncryptedReference)
Equals(Object)

Determina se l'oggetto specificato è uguale all'oggetto corrente.

(Ereditato da Object)
GetHashCode()

Funge da funzione hash predefinita.

(Ereditato da Object)
GetType()

Ottiene l'oggetto Type dell'istanza corrente.

(Ereditato da Object)
GetXml()

Restituisce la rappresentazione XML dell'oggetto CipherReference.

LoadXml(XmlElement)

Carica le informazioni XML nell'elemento <CipherReference> nella crittografia XML.

MemberwiseClone()

Crea una copia superficiale dell'oggetto Object corrente.

(Ereditato da Object)
ToString()

Restituisce una stringa che rappresenta l'oggetto corrente.

(Ereditato da Object)

Si applica a