Hinweis
Für den Zugriff auf diese Seite ist eine Autorisierung erforderlich. Sie können versuchen, sich anzumelden oder das Verzeichnis zu wechseln.
Für den Zugriff auf diese Seite ist eine Autorisierung erforderlich. Sie können versuchen, das Verzeichnis zu wechseln.
Ermittelt den angegebenen URL, um zu bestimmen, ob er ein Discovery-Dokument darstellt.
Namespace: System.Web.Services.Discovery
Assembly: System.Web.Services (in system.web.services.dll)
Syntax
'Declaration
Public Function Discover ( _
url As String _
) As DiscoveryDocument
'Usage
Dim instance As DiscoveryClientProtocol
Dim url As String
Dim returnValue As DiscoveryDocument
returnValue = instance.Discover(url)
public DiscoveryDocument Discover (
string url
)
public:
DiscoveryDocument^ Discover (
String^ url
)
public DiscoveryDocument Discover (
String url
)
public function Discover (
url : String
) : DiscoveryDocument
Parameter
- url
Der URL, bei dem das XML Web Services Discovery-Tool beginnt.
Rückgabewert
Ein DiscoveryDocument, das die Ergebnisse der Ausführung des XML Web Services Discovery-Tools unter dem angegebenen URL enthält.
Ausnahmen
| Ausnahmetyp | Bedingung |
|---|---|
Beim Zugriff auf den angegebenen URL wurde ein anderer HTTP-Statuscode als OK zurückgegeben. |
|
Der url-Parameter ist ein gültiger URL, er zeigt jedoch nicht auf ein gültiges Discovery-Dokument. |
Hinweise
Die Discover-Methode erwartet, dass der angegebene URL ein Discovery-Dokument darstellt. Wenn der URL auf eine Dienstbeschreibung oder ein XML-Schema verweist, wird eine Ausnahme ausgelöst. Rufen Sie zum Ermitteln eines XML-Schemas oder einer Dienstbeschreibung die DiscoverAny-Methode auf.
Wenn der angegebene URL auf ein gültiges Discovery-Dokument zeigt, wird das Discovery-Dokument unter dem angegebenen URL der Documents-Auflistung und der References-Auflistung hinzugefügt. Darüber hinaus werden der References-Auflistung im Discovery-Dokument enthaltene Verweise hinzugefügt. Es wird jedoch nicht überprüft, ob sie auf gültige Discovery-Dokumente zeigen. Wenn Sie die Verweise überprüfen möchten, zeigen Sie auf gültige Discovery-Dokumente, um die ResolveAll-Methode oder die ResolveOneLevel-Methode aufzurufen.
Beispiel
Das folgende Codebeispiel ist ein Web Form, das ein DataGrid mit den ausführlichen Informationen über die Dokumente in der Documents-Eigenschaft zusammen mit den während der Ausführung des XML Web Services Discovery-Tools in den einzelnen Dokumenten gefundenen Verweisen füllt. Die PopulateGrid-Methode füllt das DataGrid mit den Ergebnissen des Aufrufs von Discover, worauf ein Aufruf von ResolveAll folgt.
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
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>";
}
Plattformen
Windows 98, Windows 2000 SP4, Windows Millennium Edition, Windows Server 2003, Windows XP Media Center Edition, Windows XP Professional x64 Edition, Windows XP SP2, Windows XP Starter Edition
.NET Framework unterstützt nicht alle Versionen sämtlicher Plattformen. Eine Liste der unterstützten Versionen finden Sie unter Systemanforderungen.
Versionsinformationen
.NET Framework
Unterstützt in: 2.0, 1.1, 1.0
Siehe auch
Referenz
DiscoveryClientProtocol-Klasse
DiscoveryClientProtocol-Member
System.Web.Services.Discovery-Namespace