HttpListener.EndGetContext(IAsyncResult) 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í.
Finaliza una operación asincrónica para recuperar una solicitud de cliente de entrada.
public:
System::Net::HttpListenerContext ^ EndGetContext(IAsyncResult ^ asyncResult);
public System.Net.HttpListenerContext EndGetContext (IAsyncResult asyncResult);
member this.EndGetContext : IAsyncResult -> System.Net.HttpListenerContext
Public Function EndGetContext (asyncResult As IAsyncResult) As HttpListenerContext
Parámetros
- asyncResult
- IAsyncResult
Un objeto IAsyncResult que se obtuvo al iniciar la operación asincrónica.
Devoluciones
Un objeto HttpListenerContext que representa la solicitud de cliente.
Excepciones
No se ha obtenido el valor asyncResult
llamando al método BeginGetContext(AsyncCallback, Object).
asyncResult
es null
.
Se ha producido un error en una llamada de función de Win32. Examine la propiedad ErrorCode de la excepción para determinar su causa.
Ya se llamó al método EndGetContext(IAsyncResult) para el objeto asyncResult
especificado.
Este objeto está cerrado.
Ejemplos
En el ejemplo de código siguiente se muestra la implementación de un método de devolución de llamada que llama al EndGetContext método .
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();
}
Public Shared Sub ListenerCallback(ByVal result As IAsyncResult)
Dim listener As HttpListener = CType(result.AsyncState, HttpListener)
' Call EndGetContext to complete the asynchronous operation.
Dim context As HttpListenerContext = listener.EndGetContext(result)
Dim request As HttpListenerRequest = context.Request
' Obtain a response object.
Dim response As HttpListenerResponse = context.Response
' Construct a response.
Dim responseString As String = "<HTML><BODY> Hello world!</BODY></HTML>"
Dim buffer As Byte() = System.Text.Encoding.UTF8.GetBytes(responseString)
' Get a response stream and write the response to it.
response.ContentLength64 = buffer.Length
Dim output As System.IO.Stream = response.OutputStream
output.Write(buffer, 0, buffer.Length)
' You must close the output stream.
output.Close()
End Sub
Comentarios
Se EndGetContext llama al método , normalmente dentro de un método de devolución de llamada definido por la aplicación invocado por un delegado, para obtener el HttpListenerContext objeto que contiene una solicitud de cliente entrante y su respuesta asociada. Este método completa una operación iniciada anteriormente mediante una llamada al BeginGetContext método . Si la operación no se ha completado, este método se bloquea hasta que lo haga.
Dado que llamar al método requiere el EndGetContextHttpListener objeto , este objeto normalmente se pasa a un método de devolución de llamada mediante el objeto de estado pasado al BeginGetContext método . Puede obtener este objeto de estado mediante la AsyncState propiedad del asyncResult
objeto .
Para obtener información detallada sobre el uso del modelo de programación asincrónica, vea Llamar a métodos sincrónicos de forma asincrónica.
Notas a los autores de las llamadas
Este miembro genera información de seguimiento cuando se habilita el seguimiento de red en la aplicación. Para obtener más información, vea Seguimiento de red en .NET Framework.