DiscoveryClientProtocol.Discover(String) 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í.
Detecta la dirección URL suministrada para determinar si se trata de un documento de descubrimiento.
public:
System::Web::Services::Discovery::DiscoveryDocument ^ Discover(System::String ^ url);
public System.Web.Services.Discovery.DiscoveryDocument Discover (string url);
member this.Discover : string -> System.Web.Services.Discovery.DiscoveryDocument
Public Function Discover (url As String) As DiscoveryDocument
Parámetros
- url
- String
Dirección URL en la que se inicia el proceso de descubrimiento de servicios Web XML.
Devoluciones
DiscoveryDocument que contiene los resultados del proceso de descubrimiento de servicios Web XML en la dirección URL suministrada.
Excepciones
El acceso a la dirección URL suministrada ha devuelto un código de estado HTTP distinto de OK.
El parámetro url
es una dirección URL válida, pero no señala a un documento de detección válido.
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 la detección de servicios web XML. El PopulateGrid
método rellena DataGrid con los resultados de una Discover 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;
// Only discover discovery documents, which might contain references to other types of discoverable documents.
doc = client.Discover(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
' Only discover discovery documents, which might contain references to other types of discoverable documents.
doc = client.Discover(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
El Discover método espera que la dirección URL proporcionada sea un documento de detección. Si la dirección URL hace referencia a una descripción del servicio o a un esquema XML se produce una excepción. Para detectar un esquema XML o una descripción del servicio, invoque el DiscoverAny método .
Si la dirección URL proporcionada apunta a un documento de detección válido, el documento de detección en la dirección URL proporcionada se agrega a la Documents colección y References . Además, las referencias dentro del documento de detección se agregan a la References colección, pero no se comprueban para que apunten a documentos de detección válidos. Para comprobar las referencias, apunte a documentos de detección válidos para invocar los ResolveAll métodos o ResolveOneLevel .