HttpWebRequest.EndGetRequestStream Methode

Definition

Beendet eine asynchrone Anforderung eines Stream-Objekts, das zum Schreiben von Daten verwendet werden soll.Ends an asynchronous request for a Stream object to use to write data.

Überlädt

EndGetRequestStream(IAsyncResult, TransportContext)

Beendet eine asynchrone Anforderung eines Stream-Objekts, das zum Schreiben von Daten verwendet wird und das dem Datenstrom zugeordnete TransportContext ausgibt.Ends an asynchronous request for a Stream object to use to write data and outputs the TransportContext associated with the stream.

EndGetRequestStream(IAsyncResult)

Beendet eine asynchrone Anforderung eines Stream-Objekts, das zum Schreiben von Daten verwendet werden soll.Ends an asynchronous request for a Stream object to use to write data.

EndGetRequestStream(IAsyncResult, TransportContext)

Beendet eine asynchrone Anforderung eines Stream-Objekts, das zum Schreiben von Daten verwendet wird und das dem Datenstrom zugeordnete TransportContext ausgibt.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 ^ % transportContext);
public System.IO.Stream EndGetRequestStream (IAsyncResult asyncResult, out System.Net.TransportContext transportContext);
override this.EndGetRequestStream : IAsyncResult * TransportContext -> System.IO.Stream
Public Function EndGetRequestStream (asyncResult As IAsyncResult, ByRef transportContext As TransportContext) As Stream

Parameter

asyncResult
IAsyncResult

Die ausstehende Anforderung für einen Datenstrom.The pending request for a stream.

context
TransportContext

Der TransportContext für den Stream.The TransportContext for the Stream.

Gibt zurück

Ein Stream, der zum Schreiben von Anforderungsdaten verwendet werden soll.A Stream to use to write request data.

Ausnahmen

asyncResult wurde von der aktuellen Instanz bei einem Aufruf von BeginGetRequestStream(AsyncCallback, Object) nicht zurückgegeben.asyncResult was not returned by the current instance from a call to BeginGetRequestStream(AsyncCallback, Object).

asyncResult ist null.asyncResult is null.

Diese Methode wurde zuvor mit asyncResult aufgerufen.This method was called previously using asyncResult.

Die Anforderung wurde nicht abgeschlossen, und es ist kein Stream verfügbar.The request did not complete, and no stream is available.

Abort() wurde bereits aufgerufen.Abort() was previously called.

- oder --or- Fehler beim Verarbeiten der Anforderung.An error occurred while processing the request.

Hinweise

Die EndGetRequestStream-Methode schließt eine asynchrone Anforderung für einen Stream ab, der von der BeginGetRequestStream-Methode gestartet wurde, und gibt die TransportContext aus, die dem Stream zugeordnet ist.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. Nachdem das Stream Objekt zurückgegeben wurde, können Sie mithilfe der Stream.Write-Methode Daten mit dem HttpWebRequest senden.After the Stream object has been returned, you can send data with the HttpWebRequest by using the Stream.Write method.

Einige Anwendungen, die die integrierte Windows-Authentifizierung mit erweitertem Schutz verwenden, müssen möglicherweise die von HttpWebRequest verwendete Transportschicht Abfragen, um das channelbindungstoken (CBT) aus dem zugrunde liegenden TLS-Kanal abzurufen.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. Die GetRequestStream-Methode ermöglicht den Zugriff auf diese Informationen für HTTP-Methoden, die über einen Anforderungs Text verfügen (POST und PUT Anforderungen).The GetRequestStream method provides access to this information for HTTP methods which have a request body (POST and PUT requests). Dies ist nur erforderlich, wenn die Anwendung ihre eigene Authentifizierung implementiert und Zugriff auf das CBT benötigt.This is only needed if the application is implementing its own authentication and needs access to the CBT.

Hinweis

Wenn eine Anwendung den Wert der ContentLength-Eigenschaft festlegen muss, muss dies erfolgen, bevor der Stream abgerufen und Daten in den Stream geschrieben werden.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.

Achtung

Sie müssen die Stream.Close-Methode aufzurufen, um den Stream zu schließen und die Verbindung für die Wiederverwendung freizugeben.You must call the Stream.Close method to close the stream and release the connection for reuse. Wenn Sie den Stream nicht schließen, wird für die Anwendung keine Verbindung mehr hergestellt.Failure to close the stream causes your application to run out of connections.

Hinweis

Dieser Member gibt Ablaufverfolgungsinformationen aus, wenn Sie die Netzwerkablaufverfolgung in der Anwendung aktivieren.This member outputs trace information when you enable network tracing in your application. Weitere Informationen finden Sie unter Netzwerk Ablauf Verfolgung in der .NET Framework.For more information, see Network Tracing in the .NET Framework.

Siehe auch

EndGetRequestStream(IAsyncResult)

Beendet eine asynchrone Anforderung eines Stream-Objekts, das zum Schreiben von Daten verwendet werden soll.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

Parameter

asyncResult
IAsyncResult

Die ausstehende Anforderung für einen Stream.The pending request for a stream.

Gibt zurück

Ein Stream, der zum Schreiben von Anforderungsdaten verwendet werden soll.A Stream to use to write request data.

Ausnahmen

asyncResult ist null.asyncResult is null.

Die Anforderung wurde nicht abgeschlossen, und es ist kein Stream verfügbar.The request did not complete, and no stream is available.

asyncResult wurde von der aktuellen Instanz bei einem Aufruf von BeginGetRequestStream(AsyncCallback, Object) nicht zurückgegeben.asyncResult was not returned by the current instance from a call to BeginGetRequestStream(AsyncCallback, Object).

Diese Methode wurde zuvor unter Verwendung von asyncResult aufgerufen.This method was called previously using asyncResult.

Abort() wurde bereits aufgerufen.Abort() was previously called.

- oder --or- Fehler beim Verarbeiten der Anforderung.An error occurred while processing the request.

Beispiele

Im folgenden Codebeispiel wird die EndGetRequestStream-Methode verwendet, um eine asynchrone Anforderung für eine Streaminstanz zu beenden.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

Hinweise

Die EndGetRequestStream-Methode schließt eine asynchrone Anforderung für einen Stream ab, der von der BeginGetRequestStream-Methode gestartet wurde.The EndGetRequestStream method completes an asynchronous request for a stream that was started by the BeginGetRequestStream method. Nachdem das Stream Objekt zurückgegeben wurde, können Sie mithilfe der Stream.Write-Methode Daten mit dem HttpWebRequest senden.After the Stream object has been returned, you can send data with the HttpWebRequest by using the Stream.Write method.

Hinweis

Sie müssen den Wert der ContentLength-Eigenschaft festlegen, bevor Sie Daten in den Stream schreiben.You must set the value of the ContentLength property before writing data to the stream.

Achtung

Sie müssen die Stream.Close-Methode aufzurufen, um den Stream zu schließen und die Verbindung für die Wiederverwendung freizugeben.You must call the Stream.Close method to close the stream and release the connection for reuse. Wenn Sie den Stream nicht schließen, wird für die Anwendung keine Verbindung mehr hergestellt.Failure to close the stream causes your application to run out of connections.

Hinweis

Dieser Member gibt Ablaufverfolgungsinformationen aus, wenn Sie die Netzwerkablaufverfolgung in der Anwendung aktivieren.This member outputs trace information when you enable network tracing in your application. Weitere Informationen finden Sie unter Netzwerk Ablauf Verfolgung in der .NET Framework.For more information, see Network Tracing in the .NET Framework.

Gilt für: