HttpWebRequest.EndGetRequestStream Metoda

Definicja

Zamyka asynchroniczne żądanie dla obiektu Stream, który ma być używany do zapisywania danych.Ends an asynchronous request for a Stream object to use to write data.

Przeciążenia

EndGetRequestStream(IAsyncResult, TransportContext)

Zamyka asynchroniczne żądanie dla obiektu Stream, który będzie używany do zapisywania danych i wyprowadza TransportContext skojarzone ze strumieniem.Ends an asynchronous request for a Stream object to use to write data and outputs the TransportContext associated with the stream.

EndGetRequestStream(IAsyncResult)

Zamyka asynchroniczne żądanie dla obiektu Stream, który ma być używany do zapisywania danych.Ends an asynchronous request for a Stream object to use to write data.

EndGetRequestStream(IAsyncResult, TransportContext)

Zamyka asynchroniczne żądanie dla obiektu Stream, który będzie używany do zapisywania danych i wyprowadza TransportContext skojarzone ze strumieniem.Ends an asynchronous request for a Stream object to use to write data and outputs the TransportContext associated with the stream.

public:
 System::IO::Stream ^ EndGetRequestStream(IAsyncResult ^ asyncResult, [Runtime::InteropServices::Out] System::Net::TransportContext ^ % context);
public:
 System::IO::Stream ^ EndGetRequestStream(IAsyncResult ^ asyncResult, [Runtime::InteropServices::Out] System::Net::TransportContext ^ % transportContext);
public System.IO.Stream EndGetRequestStream (IAsyncResult asyncResult, out System.Net.TransportContext context);
public System.IO.Stream EndGetRequestStream (IAsyncResult asyncResult, out System.Net.TransportContext transportContext);
override this.EndGetRequestStream : IAsyncResult * TransportContext -> System.IO.Stream
override this.EndGetRequestStream : IAsyncResult * TransportContext -> System.IO.Stream
Public Function EndGetRequestStream (asyncResult As IAsyncResult, ByRef context As TransportContext) As Stream
Public Function EndGetRequestStream (asyncResult As IAsyncResult, ByRef transportContext As TransportContext) As Stream

Parametry

asyncResult
IAsyncResult

Oczekujące żądanie strumienia.The pending request for a stream.

contexttransportContext
TransportContext

Obiekt TransportContext dla obiektu Stream.The TransportContext for the Stream.

Zwraca

Stream

Stream używany do zapisywania danych żądania.A Stream to use to write request data.

Wyjątki

asyncResult nie został zwrócony przez bieżące wystąpienie z wywołania do BeginGetRequestStream(AsyncCallback, Object).asyncResult was not returned by the current instance from a call to BeginGetRequestStream(AsyncCallback, Object).

Parametr asyncResult ma wartość null.asyncResult is null.

Ta metoda została wywołana wcześniej przy użyciu asyncResult.This method was called previously using asyncResult.

Żądanie nie zostało ukończone i strumień nie jest dostępny.The request did not complete, and no stream is available.

Abort() została wcześniej wywołana.Abort() was previously called.

— lub —-or- Podczas przetwarzania żądania wystąpił błąd.An error occurred while processing the request.

Uwagi

Metoda EndGetRequestStream wykonuje asynchroniczne żądanie dla strumienia, który został uruchomiony przez metodę BeginGetRequestStream i wyprowadza TransportContext skojarzone ze strumieniem.The EndGetRequestStream method completes an asynchronous request for a stream that was started by the BeginGetRequestStream method and outputs the TransportContext associated with the stream. Po zwróceniu obiektu Stream można wysłać dane za pomocą HttpWebRequest przy użyciu metody Stream.Write.After the Stream object has been returned, you can send data with the HttpWebRequest by using the Stream.Write method.

Niektóre aplikacje używające zintegrowanego uwierzytelniania systemu Windows z ochroną rozszerzoną mogą wymagać, aby można było wysyłać zapytania do warstwy transportowej używanej przez HttpWebRequest w celu pobrania tokenu powiązania kanału (CBT) z bazowego kanału TLS.Some applications that use integrated Windows authentication with extended protection may need to be able to query the transport layer used by HttpWebRequest in order to retrieve the channel binding token (CBT) from the underlying TLS channel. Metoda GetRequestStream zapewnia dostęp do tych informacji dla metod HTTP, które mają treść żądania (POST i PUT żądania).The GetRequestStream method provides access to this information for HTTP methods which have a request body (POST and PUT requests). Jest to potrzebne tylko wtedy, gdy aplikacja implementuje własne uwierzytelnianie i wymaga dostępu do CBT.This is only needed if the application is implementing its own authentication and needs access to the CBT.

Uwaga

Jeśli aplikacja wymaga ustawienia wartości właściwości ContentLength, należy to zrobić przed pobraniem strumienia i zapisem danych.If an application needs to set the value of the ContentLength property, then this must be done before retrieving the stream and writing data to it.

Przestroga

Należy wywołać metodę Stream.Close, aby zamknąć strumień i zwolnić połączenie w celu ponownego użycia.You must call the Stream.Close method to close the stream and release the connection for reuse. Niepowodzenie zamknięcia strumienia powoduje brak połączeń aplikacji.Failure to close the stream causes your application to run out of connections.

Uwaga

Ten element członkowski generuje informacje ze śledzenia pod warunkiem włączenia funkcji śledzenia sieci w aplikacji.This member outputs trace information when you enable network tracing in your application. Aby uzyskać więcej informacji, zobacz Śledzenie sieci w .NET Framework.For more information, see Network Tracing in the .NET Framework.

Zobacz też

EndGetRequestStream(IAsyncResult)

Zamyka asynchroniczne żądanie dla obiektu Stream, który ma być używany do zapisywania danych.Ends an asynchronous request for a Stream object to use to write data.

public:
 override System::IO::Stream ^ EndGetRequestStream(IAsyncResult ^ asyncResult);
public override System.IO.Stream EndGetRequestStream (IAsyncResult asyncResult);
override this.EndGetRequestStream : IAsyncResult -> System.IO.Stream
Public Overrides Function EndGetRequestStream (asyncResult As IAsyncResult) As Stream

Parametry

asyncResult
IAsyncResult

Oczekujące żądanie strumienia.The pending request for a stream.

Zwraca

Stream

Stream używany do zapisywania danych żądania.A Stream to use to write request data.

Wyjątki

Parametr asyncResult ma wartość null.asyncResult is null.

Żądanie nie zostało ukończone i strumień nie jest dostępny.The request did not complete, and no stream is available.

asyncResult nie został zwrócony przez bieżące wystąpienie z wywołania do BeginGetRequestStream(AsyncCallback, Object).asyncResult was not returned by the current instance from a call to BeginGetRequestStream(AsyncCallback, Object).

Ta metoda została wywołana wcześniej przy użyciu asyncResult.This method was called previously using asyncResult.

Abort() została wcześniej wywołana.Abort() was previously called.

— lub —-or- Podczas przetwarzania żądania wystąpił błąd.An error occurred while processing the request.

Przykłady

Poniższy przykład kodu używa metody EndGetRequestStream, aby zakończyć asynchroniczne żądanie dla wystąpienia strumienia.The following code example uses the EndGetRequestStream method to end an asynchronous request for a stream instance.

#using <System.dll>

using namespace System;
using namespace System::Net;
using namespace System::IO;
using namespace System::Text;
using namespace System::Threading;
ref class HttpWebRequestBeginGetRequest
{
public:
   static ManualResetEvent^ allDone = gcnew ManualResetEvent( false );
   static void Main()
   {
      
      // Create a new HttpWebRequest object.
      HttpWebRequest^ request = dynamic_cast<HttpWebRequest^>(WebRequest::Create( "http://www.contoso.com/example.aspx" ));
      
      // 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.    
      AsyncCallback^ del = gcnew AsyncCallback(GetRequestStreamCallback);
      request->BeginGetRequestStream( del, 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 = dynamic_cast<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.
        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
        AsyncCallback^ del = gcnew AsyncCallback(GetResponseCallback);
        request->BeginGetResponse(del, request);
    }

   static void GetResponseCallback(IAsyncResult^ asynchronousResult)
   {
      HttpWebRequest^ request = dynamic_cast<HttpWebRequest^>(asynchronousResult->AsyncState);

      // End the operation
      HttpWebResponse^ response = dynamic_cast<HttpWebResponse^>(request->EndGetResponse(asynchronousResult));
      Stream^ streamResponse = response->GetResponseStream();
      StreamReader^ streamRead = gcnew StreamReader(streamResponse);
      String^ responseString = streamRead->ReadToEnd();
      Console::WriteLine(responseString);
      // Close the stream object
      streamResponse->Close();
      streamRead->Close();

      // Release the HttpWebResponse
      response->Close();
      allDone->Set();
   }
};

void main()
{
   HttpWebRequestBeginGetRequest::Main();
}

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

Uwagi

Metoda EndGetRequestStream wykonuje asynchroniczne żądanie dla strumienia, który został uruchomiony przez metodę BeginGetRequestStream.The EndGetRequestStream method completes an asynchronous request for a stream that was started by the BeginGetRequestStream method. Po zwróceniu obiektu Stream można wysłać dane za pomocą HttpWebRequest przy użyciu metody Stream.Write.After the Stream object has been returned, you can send data with the HttpWebRequest by using the Stream.Write method.

Uwaga

Przed zapisaniem danych w strumieniu należy ustawić wartość właściwości ContentLength.You must set the value of the ContentLength property before writing data to the stream.

Przestroga

Należy wywołać metodę Stream.Close, aby zamknąć strumień i zwolnić połączenie w celu ponownego użycia.You must call the Stream.Close method to close the stream and release the connection for reuse. Niepowodzenie zamknięcia strumienia powoduje brak połączeń aplikacji.Failure to close the stream causes your application to run out of connections.

Uwaga

Ten element członkowski generuje informacje ze śledzenia pod warunkiem włączenia funkcji śledzenia sieci w aplikacji.This member outputs trace information when you enable network tracing in your application. Aby uzyskać więcej informacji, zobacz Śledzenie sieci w .NET Framework.For more information, see Network Tracing in the .NET Framework.

Dotyczy