Partager via


DiscoveryClientProtocol.ResolveAll Méthode

Définition

Résout toutes les références aux documents de découverte, aux schémas XSD (XML Schema Definition) et aux descriptions de service dans la propriété References, ainsi que les références trouvées dans des documents de découverte référencés.

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

Exemples

L’exemple de code suivant est un formulaire Web qui remplit un DataGrid avec les détails des documents de la Documents propriété, ainsi que les références trouvées dans chaque document pendant une découverte de services Web XML. La PopulateGrid méthode remplit les DataGrid résultats d’un DiscoverAny appel suivi d’un appel à 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

Remarques

ResolveAll résout toutes les références valides qu’il trouve et les place dans la Documents propriété. À la fois ResolveAll , téléchargez et ResolveOneLevel vérifiez les schémas XSD et les descriptions de service dans la References propriété. Toutefois, les deux méthodes diffèrent dans la façon dont elles gèrent les documents de découverte. ResolveOneLevel résout toutes les références dans les documents de découverte dans la References propriété ; si un document de découverte contient des références à d’autres documents de découverte, ResolveOneLevel résout uniquement ces documents de découverte. Les documents de découverte trouvés dans ces documents de découverte imbriqués ResolveOneLeveld’un niveau profond ne sont pas résolus par ; alors qu’ils ResolveAll les résolvent tous. ResolveAll continue de résoudre les références dans les documents de découverte imbriqués jusqu’à ce qu’il n’y ait plus de références.

Les erreurs qui se produisent pendant le processus de vérification effectué par ResolveAll ne sont pas levées au moment de l’occurrence, mais plutôt collectées et ajoutées à la Errors propriété.

S’applique à