Auf Englisch lesen

Freigeben über


HttpListener.BeginGetContext(AsyncCallback, Object) Methode

Definition

Startet den asynchronen Abruf einer eingehenden Anforderung.

C#
public IAsyncResult BeginGetContext(AsyncCallback? callback, object? state);
C#
public IAsyncResult BeginGetContext(AsyncCallback callback, object state);

Parameter

callback
AsyncCallback

Ein AsyncCallback-Delegat, der auf die Methode verweist, die aufgerufen werden soll, wenn eine Clientanforderung verfügbar ist.

state
Object

Ein benutzerdefiniertes Objekt, das Informationen über den Vorgang enthält. Dieses Objekt wird bei Abschluss des Vorgangs an den callback-Delegaten übergeben.

Gibt zurück

Ein IAsyncResult-Objekt, das den Status des asynchronen Vorgangs angibt.

Ausnahmen

Bei einem Win32-Funktionsaufruf ist ein Fehler aufgetreten. Überprüfen Sie die ErrorCode-Eigenschaft der Ausnahme, um die Ursache der Ausnahme zu bestimmen.

Dieses Objekt wurde nicht gestartet oder ist gegenwärtig angehalten.

Dieses Objekt ist geschlossen.

Beispiele

Im folgenden Codebeispiel wird die Verwendung der BeginGetContext -Methode zum Angeben einer Rückrufmethode veranschaulicht, die eingehende Clientanforderungen verarbeitet.

C#

public static void NonblockingListener(string [] prefixes)
{
    HttpListener listener = new HttpListener();
    foreach (string s in prefixes)
    {
        listener.Prefixes.Add(s);
    }
    listener.Start();
    IAsyncResult result = listener.BeginGetContext(new AsyncCallback(ListenerCallback),listener);
    // Applications can do some work here while waiting for the
    // request. If no work can be done until you have processed a request,
    // use a wait handle to prevent this thread from terminating
    // while the asynchronous operation completes.
    Console.WriteLine("Waiting for request to be processed asyncronously.");
    result.AsyncWaitHandle.WaitOne();
    Console.WriteLine("Request processed asyncronously.");
    listener.Close();
}

Im folgenden Codebeispiel wird eine Rückrufmethode implementiert.

C#
public static void ListenerCallback(IAsyncResult result)
{
    HttpListener listener = (HttpListener) result.AsyncState;
    // Call EndGetContext to complete the asynchronous operation.
    HttpListenerContext context = listener.EndGetContext(result);
    HttpListenerRequest request = context.Request;
    // Obtain a response object.
    HttpListenerResponse response = context.Response;
    // Construct a response.
    string responseString = "<HTML><BODY> Hello world!</BODY></HTML>";
    byte[] buffer = System.Text.Encoding.UTF8.GetBytes(responseString);
    // Get a response stream and write the response to it.
    response.ContentLength64 = buffer.Length;
    System.IO.Stream output = response.OutputStream;
    output.Write(buffer,0,buffer.Length);
    // You must close the output stream.
    output.Close();
}

Hinweise

Die BeginGetContext -Methode beginnt einen asynchronen (nicht blockierenden) Aufruf, um eingehende Clientanforderungen zu empfangen. Vor dem Aufrufen dieser Methode müssen Sie die Start -Methode aufrufen und mindestens ein URI-Präfix (Uniform Resource Identifier) hinzufügen, auf das überwacht werden soll, indem Sie die URI-Zeichenfolgen der HttpListenerPrefixCollection von der Prefixes -Eigenschaft zurückgegebenen hinzufügen.

Der asynchrone Vorgang muss durch Aufrufen der EndGetContext -Methode abgeschlossen werden. In der Regel wird die -Methode vom callback Delegaten aufgerufen.

Diese Methode wird nicht blockiert, während der Vorgang abgeschlossen ist. Um eine eingehende Anforderung abzurufen und zu blockieren, bis der Vorgang abgeschlossen ist, rufen Sie die -Methode auf GetContext .

Ausführliche Informationen zur Verwendung des asynchronen Programmiermodells finden Sie unter Asynchrones Aufrufen synchroner Methoden.

Hinweise für Aufrufer

Dieser Member gibt Ablaufverfolgungsinformationen aus, wenn Sie die Netzwerkablaufverfolgung in der Anwendung aktivieren. Weitere Informationen finden Sie unter Netzwerkablaufverfolgung in .NET Framework.

Gilt für:

Produkt Versionen
.NET Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9, 10
.NET Framework 2.0, 3.0, 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1
.NET Standard 2.0, 2.1