Freigeben über


DiscoveryClientProtocol.ResolveOneLevel Methode

Definition

Löst alle Verweise auf Discovery-Dokumente, XSD-Schemas (XML Schema Definition) und Dienstbeschreibungen in References sowie Verweise auf, die in diesen Discovery-Dokumenten gefunden wurden.

public:
 void ResolveOneLevel();
public void ResolveOneLevel ();
member this.ResolveOneLevel : unit -> unit
Public Sub ResolveOneLevel ()

Beispiele

Das folgende Codebeispiel ist ein Webformular, das ein DataGrid mit den Details zu den Dokumenten in der Documents Eigenschaft zusammen mit den Verweisen füllt, die während einer XML-Webdienstermittlung in jedem Dokument gefunden wurden. Die PopulateGrid -Methode füllt die DataGrid mit den Ergebnissen eines DiscoverAny Aufrufs gefolgt von einem Aufruf von ResolveOneLevelaus.

 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 references just one level deep/
        client.ResolveOneLevel();
      }
      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 references just one level deep.
     client.ResolveOneLevel()
           
    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

ResolveOneLevel löst alle gültigen Verweise auf, die er findet, und platziert sie in der Documents -Eigenschaft. ResolveOneLevel Laden ResolveAll Sie XSD-Schemas und Dienstbeschreibungen herunter, und überprüfen Sie sie in der References Eigenschaft. Die beiden Methoden unterscheiden sich jedoch im Umgang mit Ermittlungsdokumenten. ResolveOneLevel löst alle Verweise in Ermittlungsdokumenten innerhalb der References -Eigenschaft auf. Wenn ein Ermittlungsdokument Verweise auf andere Ermittlungsdokumente enthält, ResolveOneLevel werden nur diese Ermittlungsdokumente aufgelöst. Ermittlungsdokumente, die in diesen Ermittlungsdokumenten gefunden werden, die eine Ebene tief geschachtelt sind, werden nicht durch ResolveOneLevelaufgelöst, während ResolveAll sie alle aufgelöst werden. ResolveAll löst Weiterhin Verweise in geschachtelten Ermittlungsdokumenten auf, bis keine verweise mehr vorhanden sind.

Fehler, die während des Überprüfungsprozesses von auftreten ResolveOneLevel , werden nicht zum Zeitpunkt des Auftretens ausgelöst, sondern gesammelt und der Errors Eigenschaft hinzugefügt.

Gilt für: