DiscoveryClientProtocol.ResolveAll Methode
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.
Löst alle Verweise auf Discovery-Dokumente, XSD-Schemas (XML Schema Definition) und Dienstbeschreibungen in der References-Eigenschaft sowie alle gefundenen Verweise in Discovery-Dokumenten auf, auf die verwiesen wurde.
public:
void ResolveAll();
public void ResolveAll ();
member this.ResolveAll : unit -> unit
Public Sub ResolveAll ()
Beispiele
Im folgenden Codebeispiel handelt es sich um ein Webformular, das die DataGrid Details zu den Dokumenten in der Documents Eigenschaft zusammen mit den Verweisen auf jedes Dokument während einer XML-Webdienstermittlung auffüllt. Die PopulateGrid
Methode füllt die DataGrid Ergebnisse aus einem DiscoverAny Aufruf gefolgt von einem Aufruf von ResolveAll.
protected void Discover_Click(object Source, EventArgs e)
{
// Specify the URL to discover.
string sourceUrl = DiscoURL.Text;
// Specify the URL to save discovery results to or read from.
string outputDirectory = DiscoDir.Text;
DiscoveryClientProtocol client = new DiscoveryClientProtocol();
// Use default credentials to access the URL being discovered.
client.Credentials = CredentialCache.DefaultCredentials;
try
{
DiscoveryDocument doc;
// Discover the URL for any discoverable documents.
doc = client.DiscoverAny(sourceUrl);
// Resolve all possible references from the supplied URL.
client.ResolveAll();
}
catch ( Exception e2)
{
DiscoveryResultsGrid.Columns.Clear();
Status.Text = e2.Message;
}
// If documents were discovered, display the results in a data grid.
if (client.Documents.Count > 0)
PopulateGrid(client);
// Save the discovery results to disk.
DiscoveryClientResultCollection results = client.WriteAll(outputDirectory, "results.discomap");
Status.Text = "The following file holds the links to each of the discovery results: <b>" +
Path.Combine(outputDirectory,"results.discomap") + "</b>";
}
Public Sub Discover_Click(Source As Object, e as EventArgs )
' Specify the URL to discover.
Dim sourceUrl as String = DiscoURL.Text
' Specify the URL to save discovery results to or read from.
Dim outputDirectory As String = DiscoDir.Text
Dim client as DiscoveryClientProtocol = new DiscoveryClientProtocol()
' Use default credentials to access the URL being discovered.
client.Credentials = CredentialCache.DefaultCredentials
Try
Dim doc As DiscoveryDocument
' Discover the URL for any discoverable documents.
doc = client.DiscoverAny(sourceUrl)
' Resolve all possible references from the supplied URL.
client.ResolveAll()
Catch e2 As Exception
DiscoveryResultsGrid.Columns.Clear()
Status.Text = e2.Message
End Try
' If documents were discovered, display the results in a data grid.
If (client.Documents.Count > 0) Then
'populate our Grid with the discovery results
PopulateGrid(client)
End If
' Save the discovery results to disk.
Dim results As DiscoveryClientResultCollection
results = client.WriteAll(outputDirectory, "results.discomap")
Status.Text = "The following file holds the links to each of the discovery results: <b>" + _
Path.Combine(outputDirectory,"results.discomap") + "</b>"
End Sub
Hinweise
ResolveAll löst alle gültigen Verweise auf, die gefunden werden, und platziert sie in der Documents Eigenschaft. Sowohl ResolveAll als auch herunterladen und ResolveOneLevel überprüfen Sie XSD-Schemas und Dienstbeschreibungen in der References Eigenschaft. Die beiden Methoden unterscheiden sich jedoch darin, wie sie Ermittlungsdokumente behandeln. ResolveOneLevel löst alle Verweise in Discoverydokumenten innerhalb der References Eigenschaft auf. Wenn ein Discoverydokument Verweise auf andere Ermittlungsdokumente enthält, ResolveOneLevel werden nur diese Ermittlungsdokumente aufgelöst. Ermittlungsdokumente, die in diesen Ermittlungsdokumenten gefunden wurden, die eine Ebene tief geschachtelt sind, werden nicht aufgelöst, während ResolveAll sie alle aufgelöst ResolveOneLevelwerden. ResolveAll wird weiterhin Verweise in geschachtelten Ermittlungsdokumenten aufgelöst, bis keine weiteren Verweise vorhanden sind.
Fehler, die während des Überprüfungsprozesses auftreten, werden ResolveAll nicht zum Zeitpunkt des Auftretens ausgelöst, sondern der Eigenschaft gesammelt und hinzugefügt Errors .