HttpWebRequest.BeginGetRequestStream(AsyncCallback, Object) Método

Definição

Inicia um pedido assíncrono para que um Stream objeto seja usado para escrever dados.

public:
 override IAsyncResult ^ BeginGetRequestStream(AsyncCallback ^ callback, System::Object ^ state);
public override IAsyncResult BeginGetRequestStream(AsyncCallback callback, object state);
override this.BeginGetRequestStream : AsyncCallback * obj -> IAsyncResult
Public Overrides Function BeginGetRequestStream (callback As AsyncCallback, state As Object) As IAsyncResult

Parâmetros

callback
AsyncCallback

O AsyncCallback delegado.

state
Object

O Estado contesta este pedido.

Devoluções

E IAsyncResult que faz referência ao pedido assíncrono.

Exceções

A Method propriedade é GET ou HEAD.

-ou-

KeepAlive é true, AllowWriteStreamBuffering é false, ContentLength é -1, SendChunked é false, e Method é POST ou PUT.

O fluxo está a ser utilizado por uma chamada anterior para BeginGetRequestStream(AsyncCallback, Object)

-ou-

TransferEncoding é atribuído a um valor e SendChunked é false.

-ou-

O pool de threads está a ficar sem threads.

O validador de cache de pedidos indicou que a resposta a este pedido pode ser servida a partir da cache; no entanto, os pedidos que escrevem dados não devem usar a cache. Esta exceção pode ocorrer se estiver a usar um validador de cache personalizado que está incorretamente implementado.

Abort() foi anteriormente chamado.

Numa aplicação .NET Compact Framework, um fluxo de pedidos com comprimento de conteúdo zero não era obtido e fechado corretamente. Para mais informações sobre o tratamento de pedidos com comprimento de conteúdo zero, consulte Programação em Rede no .NET Compact Framework.

Exemplos

O exemplo de código seguinte utiliza o BeginGetRequestStream método para fazer um pedido assíncrono para uma instância de fluxo.

using System;
using System.Net;
using System.IO;
using System.Text;
using System.Threading;

class HttpWebRequestBeginGetRequest
{
    private static ManualResetEvent allDone = new ManualResetEvent(false);

    public static void Main(string[] args)
    {


        // Create a new HttpWebRequest object.
        HttpWebRequest request = (HttpWebRequest)WebRequest.Create("http://www.contoso.com/example.aspx");

        request.ContentType = "application/x-www-form-urlencoded";

        // Set the Method property to 'POST' to post data to the URI.
        request.Method = "POST";

        // start the asynchronous operation
        request.BeginGetRequestStream(new AsyncCallback(GetRequestStreamCallback), request);

        // Keep the main thread from continuing while the asynchronous
        // operation completes. A real world application
        // could do something useful such as updating its user interface.
        allDone.WaitOne();
    }

    private static void GetRequestStreamCallback(IAsyncResult asynchronousResult)
    {
        HttpWebRequest request = (HttpWebRequest)asynchronousResult.AsyncState;

        // End the operation
        Stream postStream = request.EndGetRequestStream(asynchronousResult);

        Console.WriteLine("Please enter the input data to be posted:");
        string postData = Console.ReadLine();

        // Convert the string into a byte array.
        byte[] byteArray = Encoding.UTF8.GetBytes(postData);

        // Write to the request stream.
        postStream.Write(byteArray, 0, postData.Length);
        postStream.Close();

        // Start the asynchronous operation to get the response
        request.BeginGetResponse(new AsyncCallback(GetResponseCallback), request);
    }

    private static void GetResponseCallback(IAsyncResult asynchronousResult)
    {
        HttpWebRequest request = (HttpWebRequest)asynchronousResult.AsyncState;

        // End the operation
        HttpWebResponse response = (HttpWebResponse)request.EndGetResponse(asynchronousResult);
        Stream streamResponse = response.GetResponseStream();
        StreamReader streamRead = new StreamReader(streamResponse);
        string responseString = streamRead.ReadToEnd();
        Console.WriteLine(responseString);
        // Close the stream object
        streamResponse.Close();
        streamRead.Close();

        // Release the HttpWebResponse
        response.Close();
        allDone.Set();
    }
}
Imports System.Net
Imports System.IO
Imports System.Text
Imports System.Threading

Class HttpWebRequestBeginGetRequest
    Public Shared allDone As New ManualResetEvent(False)

    Shared Sub Main()


        ' Create a new HttpWebRequest object.
        Dim request As HttpWebRequest = CType(WebRequest.Create("http://www.contoso.com/example.aspx"), _
                 HttpWebRequest)

        ' Set the ContentType property.
        request.ContentType = "application/x-www-form-urlencoded"

        '  Set the Method property to 'POST' to post data to the URI.
        request.Method = "POST"

        ' Start the asynchronous operation.		
        Dim result As IAsyncResult = _
            CType(request.BeginGetRequestStream(AddressOf GetRequestStreamCallback, request), _
            IAsyncResult)

        ' Keep the main thread from continuing while the asynchronous
        ' operation completes. A real world application
        ' could do something useful such as updating its user interface. 
        allDone.WaitOne()
    End Sub

    Private Shared Sub GetRequestStreamCallback(ByVal asynchronousResult As IAsyncResult)
        Dim request As HttpWebRequest = CType(asynchronousResult.AsyncState, HttpWebRequest)
        
        ' End the operation
        Dim postStream As Stream = request.EndGetRequestStream(asynchronousResult)
        Console.WriteLine("Please enter the input data to be posted:")
        Dim postData As [String] = Console.ReadLine()
        
        '  Convert the string into byte array.
        Dim byteArray As Byte() = Encoding.UTF8.GetBytes(postData)

        ' Write to the stream.
        postStream.Write(byteArray, 0, postData.Length)
        postStream.Close()

        ' Start the asynchronous operation to get the response
        Dim result As IAsyncResult = _
            CType(request.BeginGetResponse(AddressOf GetResponseCallback, request), _
            IAsyncResult)
    End Sub

    Private Shared Sub GetResponseCallback(ByVal asynchronousResult As IAsyncResult)
        Dim request As HttpWebRequest = CType(asynchronousResult.AsyncState, HttpWebRequest)
        
        '  Get the response.
        Dim response As HttpWebResponse = CType(request.EndGetResponse(asynchronousResult), _
           HttpWebResponse)
        
        Dim streamResponse As Stream = response.GetResponseStream()
        Dim streamRead As New StreamReader(streamResponse)
        Dim responseString As String = streamRead.ReadToEnd()
        
        Console.WriteLine(responseString)
        
        ' Close Stream object.
        streamResponse.Close()
        streamRead.Close()

        ' Release the HttpWebResponse.
        allDone.Set()
        response.Close()
    End Sub
            
End Class

Observações

Atenção

WebRequest, HttpWebRequest, ServicePoint, e WebClient são obsoletos, e não deves usá-los para novos desenvolvimentos. Utilize HttpClient em substituição.

O BeginGetRequestStream método inicia um pedido assíncrono para um fluxo usado para enviar dados para o HttpWebRequest. O método de callback assíncrono utiliza o EndGetRequestStream método para devolver o fluxo real.

O BeginGetRequestStream método requer algumas tarefas de configuração síncronas para serem concluídas (resolução DNS, deteção de proxy e ligação ao socket TCP, por exemplo) antes de este método se tornar assíncrono. Como resultado, este método nunca deve ser chamado numa thread de interface de utilizador (UI) porque pode demorar um tempo considerável (até vários minutos, dependendo das definições de rede) a completar as tarefas iniciais de configuração síncrona antes de ser lançada uma exceção por erro ou o método ter sucesso.

Para saber mais sobre o pool de threads, consulte O pool de threads geridos.

Note

A sua aplicação não pode misturar métodos síncronos e assíncronos para um pedido específico. Se chamar o BeginGetRequestStream método, deve usá-lo BeginGetResponse para recuperar a resposta.

Note

Esse membro gera informações de rastreamento quando você habilita o rastreamento de rede em seu aplicativo. Para mais informações, consulte Rastreamento de Rede no .NET Framework.

Aplica-se a

Ver também