DiscoveryClientProtocol.ResolveAll Método
Definición
Importante
Parte de la información hace referencia a la versión preliminar del producto, que puede haberse modificado sustancialmente antes de lanzar la versión definitiva. Microsoft no otorga ninguna garantía, explícita o implícita, con respecto a la información proporcionada aquí.
Resuelve todas las referencias a documentos de descubrimiento, esquemas XSD (lenguaje de definición de esquemas XML) y descripciones de servicios en la propiedad References, así como las referencias encontradas en los documentos de descubrimiento a los que se hace referencia.
public:
void ResolveAll();
public void ResolveAll ();
member this.ResolveAll : unit -> unit
Public Sub ResolveAll ()
Ejemplos
El siguiente ejemplo de código es un formulario web que rellena con DataGrid los detalles sobre los documentos de la Documents propiedad junto con las referencias que se encuentran en cada documento durante una detección de servicios web XML. El PopulateGrid
método rellena DataGrid con los resultados de una DiscoverAny invocación seguida de una llamada a 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
Comentarios
ResolveAll resuelve todas las referencias válidas que encuentra y las coloca en la Documents propiedad . Tanto como ResolveAll descarguen y ResolveOneLevel comprueben esquemas XSD y descripciones de servicio en la References propiedad . Sin embargo, los dos métodos difieren en cómo controlan los documentos de detección. ResolveOneLevel resuelve todas las referencias en documentos de detección dentro de la References propiedad ; si un documento de detección contiene referencias a otros documentos de detección, ResolveOneLevel resuelve solo esos documentos de detección. Los documentos de detección que se encuentran en esos documentos de detección anidados en profundidad no se resuelven mediante ResolveOneLevel; mientras que ResolveAll los resuelve todos. ResolveAll continúa resolviendo referencias en documentos de detección anidados hasta que no haya más referencias.
Los errores que se producen durante el proceso de comprobación realizado ResolveAll por no se producen en el momento de la repetición, sino que se recopilan y agregan a la Errors propiedad .