HttpWebRequest.EndGetRequestStream Methode
Definition
Wichtig
Einige Informationen beziehen sich auf Vorabversionen, die vor dem Release ggf. grundlegend überarbeitet werden. Microsoft übernimmt hinsichtlich der hier bereitgestellten Informationen keine Gewährleistungen, seien sie ausdrücklich oder konkludent.
Beendet eine asynchrone Anforderung für ein Stream-Objekt zum Schreiben von Daten.
Überlädt
EndGetRequestStream(IAsyncResult, TransportContext) |
Beendet eine asynchrone Anforderung für ein Stream-Objekt zum Schreiben von Daten und gibt die dem Datenstrom zugeordneten TransportContext aus. |
EndGetRequestStream(IAsyncResult) |
Beendet eine asynchrone Anforderung für ein Stream-Objekt zum Schreiben von Daten. |
EndGetRequestStream(IAsyncResult, TransportContext)
- Quelle:
- HttpWebRequest.cs
- Quelle:
- HttpWebRequest.cs
- Quelle:
- HttpWebRequest.cs
Beendet eine asynchrone Anforderung für ein Stream-Objekt zum Schreiben von Daten und gibt die dem Datenstrom zugeordneten TransportContext aus.
public:
System::IO::Stream ^ EndGetRequestStream(IAsyncResult ^ asyncResult, [Runtime::InteropServices::Out] System::Net::TransportContext ^ % context);
public System.IO.Stream EndGetRequestStream (IAsyncResult asyncResult, out System.Net.TransportContext? context);
public System.IO.Stream EndGetRequestStream (IAsyncResult asyncResult, out System.Net.TransportContext context);
override this.EndGetRequestStream : IAsyncResult * TransportContext -> System.IO.Stream
Public Function EndGetRequestStream (asyncResult As IAsyncResult, ByRef context As TransportContext) As Stream
Parameter
- asyncResult
- IAsyncResult
Die ausstehende Anforderung für einen Datenstrom.
- context
- TransportContext
Die TransportContext für die Stream.
Gibt zurück
Eine Stream, die zum Schreiben von Anforderungsdaten verwendet werden soll.
Ausnahmen
asyncResult
wurde von der aktuellen Instanz nicht von einem Aufruf von BeginGetRequestStream(AsyncCallback, Object)zurückgegeben.
asyncResult
ist null
.
Diese Methode wurde zuvor mit asyncResult
aufgerufen.
Die Anforderung wurde nicht abgeschlossen, und es ist kein Datenstrom verfügbar.
Hinweise
Vorsicht
WebRequest
, HttpWebRequest
, ServicePoint
und WebClient
sind veraltet, und Sie sollten sie nicht für die neue Entwicklung verwenden. Verwenden Sie stattdessen HttpClient.
Die EndGetRequestStream-Methode schließt eine asynchrone Anforderung für einen Datenstrom ab, der von der BeginGetRequestStream-Methode gestartet wurde, und gibt die dem Datenstrom zugeordneten TransportContext aus. Nachdem das Stream-Objekt zurückgegeben wurde, können Sie Daten mit dem HttpWebRequest mithilfe der Stream.Write-Methode senden.
Einige Anwendungen, die integrierte Windows-Authentifizierung mit erweitertem Schutz verwenden, müssen möglicherweise die von HttpWebRequest verwendete Transportschicht abfragen, um das Kanalbindungstoken (CBT) aus dem zugrunde liegenden TLS-Kanal abzurufen. Die GetRequestStream-Methode bietet Zugriff auf diese Informationen für HTTP-Methoden, die über einen Anforderungstext (POST
und PUT
Anforderungen) verfügen. Dies ist nur erforderlich, wenn die Anwendung eine eigene Authentifizierung implementiert und Zugriff auf das CBT benötigt.
Anmerkung
- Wenn Sie den Wert der ContentLength-Eigenschaft festlegen müssen, bevor Sie Daten in den Datenstrom schreiben.
- Sie müssen die Stream.Close-Methode aufrufen, um den Datenstrom zu schließen und die Verbindung zur Wiederverwendung freizugeben. Wenn der Datenstrom nicht geschlossen wird, wird die Anwendung nicht mehr mit Verbindungen verbunden.
- Dieses Mitglied gibt Ablaufverfolgungsinformationen aus, wenn Sie die Netzwerkablaufverfolgung in Ihrer Anwendung aktivieren. Weitere Informationen finden Sie unter Netzwerkablaufverfolgung in .NET Framework.
Weitere Informationen
- TransportContext
- GetChannelBinding(ChannelBindingKind)
- System.Security.Authentication.ExtendedProtection
- ChannelBinding
- integrierte Windows-Authentifizierung mit erweitertem Schutz
Gilt für:
EndGetRequestStream(IAsyncResult)
- Quelle:
- HttpWebRequest.cs
- Quelle:
- HttpWebRequest.cs
- Quelle:
- HttpWebRequest.cs
Beendet eine asynchrone Anforderung für ein Stream-Objekt zum Schreiben von Daten.
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 Datenstrom.
Gibt zurück
Eine Stream, die zum Schreiben von Anforderungsdaten verwendet werden soll.
Ausnahmen
asyncResult
ist null
.
Die Anforderung wurde nicht abgeschlossen, und es ist kein Datenstrom verfügbar.
asyncResult
wurde von der aktuellen Instanz nicht von einem Aufruf von BeginGetRequestStream(AsyncCallback, Object)zurückgegeben.
Diese Methode wurde zuvor mit asyncResult
aufgerufen.
Beispiele
Im folgenden Codebeispiel wird die EndGetRequestStream-Methode verwendet, um eine asynchrone Anforderung für eine Streaminstanz zu beenden.
#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
Vorsicht
WebRequest
, HttpWebRequest
, ServicePoint
und WebClient
sind veraltet, und Sie sollten sie nicht für die neue Entwicklung verwenden. Verwenden Sie stattdessen HttpClient.
Die EndGetRequestStream-Methode schließt eine asynchrone Anforderung für einen Datenstrom ab, der von der BeginGetRequestStream-Methode gestartet wurde. Nachdem das Stream-Objekt zurückgegeben wurde, können Sie Daten mit dem HttpWebRequest mithilfe der Stream.Write-Methode senden.
Anmerkung
- Sie müssen den Wert der eigenschaft ContentLength festlegen, bevor Sie Daten in den Datenstrom schreiben.
- Sie müssen die Stream.Close-Methode aufrufen, um den Datenstrom zu schließen und die Verbindung zur Wiederverwendung freizugeben. Wenn der Datenstrom nicht geschlossen wird, wird die Anwendung nicht mehr mit Verbindungen verbunden.
- Dieses Mitglied gibt Ablaufverfolgungsinformationen aus, wenn Sie die Netzwerkablaufverfolgung in Ihrer Anwendung aktivieren. Weitere Informationen finden Sie unter Netzwerkablaufverfolgung in .NET Framework.