XmlDocument.XmlResolver Eigenschaft
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.
Legt den für die Auflösung externer Ressourcen zu verwendenden XmlResolver fest.
public:
virtual property System::Xml::XmlResolver ^ XmlResolver { void set(System::Xml::XmlResolver ^ value); };
public virtual System.Xml.XmlResolver XmlResolver { set; }
public virtual System.Xml.XmlResolver? XmlResolver { set; }
member this.XmlResolver : System.Xml.XmlResolver
Public Overridable Property XmlResolver As XmlResolver
Eigenschaftswert
Der zu verwendende XmlResolver
.
In .NET Framework, Version 1.1, kann nur ein vollständig vertrauenswürdiger Aufrufer einen XmlResolver
festlegen.
Ausnahmen
Diese Eigenschaft ist auf null
festgelegt, und es wird eine externe DTD oder Entität gefunden.
Beispiele
Im folgenden Beispiel wird ein XML-Dokument geladen, das einen Verweis auf eine DTD-Datei enthält. Die XmlResolver
-Eigenschaft wird verwendet, um die Anmeldeinformationen festzulegen, die für den Zugriff auf die Netzwerkressource erforderlich sind.
#using <System.dll>
#using <System.Xml.dll>
using namespace System;
using namespace System::IO;
using namespace System::Xml;
using namespace System::Net;
int main()
{
// Supply the credentials necessary to access the DTD file stored on the network.
XmlUrlResolver^ resolver = gcnew XmlUrlResolver;
resolver->Credentials = CredentialCache::DefaultCredentials;
// Create and load the XmlDocument.
XmlDocument^ doc = gcnew XmlDocument;
doc->XmlResolver = resolver; // Set the resolver.
doc->Load( "book5.xml" );
// Display the entity replacement text which is pulled from the DTD file.
Console::WriteLine( doc->DocumentElement->LastChild->InnerText );
}
using System;
using System.IO;
using System.Xml;
using System.Net;
public class Sample {
public static void Main() {
// Supply the credentials necessary to access the DTD file stored on the network.
XmlUrlResolver resolver = new XmlUrlResolver();
resolver.Credentials = CredentialCache.DefaultCredentials;
// Create and load the XmlDocument.
XmlDocument doc = new XmlDocument();
doc.XmlResolver = resolver; // Set the resolver.
doc.Load("book5.xml");
// Display the entity replacement text which is pulled from the DTD file.
Console.WriteLine(doc.DocumentElement.LastChild.InnerText);
}
} // End class
Imports System.IO
Imports System.Xml
Imports System.Net
public class Sample
public shared sub Main()
' Supply the credentials necessary access the DTD file stored on the network.
Dim resolver as XmlUrlResolver = new XmlUrlResolver()
resolver.Credentials = CredentialCache.DefaultCredentials
' Create and load the XmlDocument.
Dim doc as XmlDocument = new XmlDocument()
doc.XmlResolver = resolver ' Set the resolver.
doc.Load("book5.xml")
' Display the entity replacement text which is pulled from the DTD file.
Console.WriteLine(doc.DocumentElement.LastChild.InnerText)
end sub
end class
Im Beispiel werden die folgenden Datendateien als Eingabe verwendet.
book5.xml
<!DOCTYPE book SYSTEM 'http://myServer/data/books.dtd'>
<book ISBN = '1-861001-57-5'>
<title>Oberon's Legacy</title>
<price>19.95</price>
<misc>&h;</misc>
</book>
books.dtd
<!ELEMENT book (title,price,misc)>
<!ATTLIST book
genre CDATA "novel"
ISBN CDATA #REQUIRED>
<!ELEMENT title (#PCDATA)>
<!ELEMENT price (#PCDATA)>
<!ELEMENT misc (#PCDATA)>
<!ENTITY h "hardcover">
<!ENTITY p "paperback">
Hinweise
Die XmlResolver
kann verwendet werden, um DTDs zu laden oder Entitätsverweise zu erweitern. Mithilfe der XmlResolver.Credentials -Eigenschaft können Sie Anmeldeinformationen für den Zugriff auf Ressourcen festlegen, die XmlResolver
in einer sicheren Netzwerkressource gespeichert sind.
Wenn das Dokument nicht mit einem XmlReader geladen wurde (d. h. wenn es mithilfe eines Datenstroms, einer Datei usw. geladen wurde), wird das
XmlResolver
aufXmlDocument
immer verwendet.Wenn das Dokument mit einem XmlTextReadergeladen wurde, wird der Resolver auf dem
XmlTextReader
verwendet, um alle DTD-Verweise im DocumentType-Knoten aufzulösen. Der Resolver auf demXmlDocument
wird verwendet, um alle Entitätsverweise zu erweitern.Wenn das Dokument mit geladen XmlValidatingReaderwurde, wird der Resolver für nie
XmlDocument
verwendet.Wenn das Dokument mit einer Klasse geladen wurde, die erweitert
XmlReader
und entitätenXmlReader
nicht aufgelöst werden kann (CanResolveEntity gibt zurückfalse
), wird dasXmlResolver
auf verwendetXmlDocument
, um alle Verweise im DocumentType-Knoten aufzulösen und alle Entitätsverweise zu erweitern.
Hinweis
Wenn das XmlDocument
mit einem XmlReader geladen wird, für das eine XmlResolver
Festgelegte festgelegt ist, wird das XmlResolver
auf nicht XmlReader
von nach XmlDocument
Load Abschluss zwischengespeichert.
Wenn diese Eigenschaft in Version 1.1 von the.NET Framework nicht festgelegt ist, bestimmt die Vertrauensstellungsebene der Anwendung das Standardverhalten.
Fully trusted code:
Das Dokument verwendet eine Standardeinstellung XmlUrlResolver ohne Benutzeranmeldeinformationen. Wenn die Authentifizierung für den Zugriff auf eine Netzwerkressource erforderlich ist, verwenden Sie die XmlResolver
-Eigenschaft, um einen XmlResolver
mit den erforderlichen Anmeldeinformationen anzugeben.
Semi-trusted code:
Die XmlResolver
-Eigenschaft ist auf null
festgelegt. Externe Ressourcen werden nicht aufgelöst.
Weitere Informationen zur Sicherheit und zur XmlResolver
Eigenschaft finden Sie unter Auflösen externer Ressourcen.
Diese Eigenschaft ist eine Microsoft-Erweiterung des Dokumentobjektmodells (DOM).