WebRequest.EndGetRequestStream(IAsyncResult) 方法


在子代類別中覆寫時,傳回 Stream,以便將資料寫入至網際網路資源。When overridden in a descendant class, returns a Stream for writing data to the Internet resource.

 abstract System::IO::Stream ^ EndGetRequestStream(IAsyncResult ^ asyncResult);
 virtual System::IO::Stream ^ EndGetRequestStream(IAsyncResult ^ asyncResult);
public abstract System.IO.Stream EndGetRequestStream (IAsyncResult asyncResult);
public virtual System.IO.Stream EndGetRequestStream (IAsyncResult asyncResult);
abstract member EndGetRequestStream : IAsyncResult -> System.IO.Stream
abstract member EndGetRequestStream : IAsyncResult -> System.IO.Stream
override this.EndGetRequestStream : IAsyncResult -> System.IO.Stream
Public MustOverride Function EndGetRequestStream (asyncResult As IAsyncResult) As Stream
Public Overridable Function EndGetRequestStream (asyncResult As IAsyncResult) As Stream



IAsyncResult,參考資料流的暫止要求。An IAsyncResult that references a pending request for a stream.



要將資料寫入的目標 StreamA Stream to write data to.


當方法在子代類別中未覆寫時,會嘗試存取該方法。Any attempt is made to access the method, when the method is not overridden in a descendant class.


下列範例會藉由呼叫來取得和使用要求資料流程 EndGetRequestStreamThe following example obtains and uses the request stream by calling the EndGetRequestStream. EndGetRequestStream方法會完成對的非同步呼叫 BeginGetRequestStreamThe EndGetRequestStream method completes the asynchronous call to BeginGetRequestStream.

#using <System.dll>

using namespace System;
using namespace System::Net;
using namespace System::IO;
using namespace System::Text;
using namespace System::Threading;
public ref class RequestState

   // This class stores the request state of the request.
   WebRequest^ request;
      request = nullptr;


ref class WebRequest_BeginGetRequeststream
   static ManualResetEvent^ allDone = gcnew ManualResetEvent( false );
   static void ReadCallback( IAsyncResult^ asynchronousResult )
      RequestState^ myRequestState = dynamic_cast<RequestState^>(asynchronousResult->AsyncState);
      WebRequest^ myWebRequest = myRequestState->request;
      // End of the Asynchronus request.
      Stream^ streamResponse = myWebRequest->EndGetRequestStream( asynchronousResult );
      // Create a string that is to be posted to the uri.
      Console::WriteLine( "Please enter a string to be posted:" );
      String^ postData = Console::ReadLine();
      // Convert  the string into a Byte array.
      array<Byte>^byteArray = Encoding::UTF8->GetBytes( postData );
      // Write data to the stream.
      streamResponse->Write( byteArray, 0, postData->Length );


int main()
   // Create a new request to the mentioned URL.
   WebRequest^ myWebRequest = WebRequest::Create( "http://www.contoso.com" );
   // Create an instance of the RequestState and assign 'myWebRequest' to its request field.
   RequestState^ myRequestState = gcnew RequestState;
   myRequestState->request = myWebRequest;
   myWebRequest->ContentType = "application/x-www-form-urlencoded";
   // Set the 'Method' prperty  to 'POST' to post data to a Uri.
   myRequestState->request->Method = "POST";
   // Start the Asynchronous 'BeginGetRequestStream' method call.
   IAsyncResult^ r = dynamic_cast<IAsyncResult^>(myWebRequest->BeginGetRequestStream( gcnew AsyncCallback( WebRequest_BeginGetRequeststream::ReadCallback ), myRequestState ));
   WebResponse^ myWebResponse = myWebRequest->GetResponse();
   Console::WriteLine( "The String* entered has been posted." );
   Console::WriteLine( "Please wait for the response..." );
   Stream^ streamResponse = myWebResponse->GetResponseStream();
   StreamReader^ streamRead = gcnew StreamReader( streamResponse );
   array<Char>^readBuff = gcnew array<Char>(256);
   int count = streamRead->Read( readBuff, 0, 256 );
   Console::WriteLine( "The contents of the HTML page are " );
   while ( count > 0 )
      String^ outputData = gcnew String( readBuff,0,count );
      Console::Write( outputData );
      count = streamRead->Read( readBuff, 0, 256 );

   // Release the HttpWebResponse Resource.

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

public class RequestState
    // This class stores the request state of the request.
    public WebRequest request;    
    public RequestState()
        request = null;

class WebRequest_BeginGetRequeststream
    public static ManualResetEvent allDone= new ManualResetEvent(false);
    static void Main()
            // Create a new request to the mentioned URL.
            WebRequest myWebRequest= WebRequest.Create("http://www.contoso.com");

            // Create an instance of the RequestState and assign 
            // 'myWebRequest' to it's request field.
            RequestState myRequestState = new RequestState();
            myRequestState.request = myWebRequest;

            // Set the 'Method' property to 'POST' to post data to a Uri.
            // Start the Asynchronous 'BeginGetRequestStream' method call.
            IAsyncResult r=(IAsyncResult) myWebRequest.BeginGetRequestStream(
                new AsyncCallback(ReadCallback),myRequestState);
            // Pause the current thread until the async operation completes.
            Console.WriteLine("main thread waiting...");
            // Assign the response object of 'WebRequest' to a 'WebResponse' variable.
            WebResponse myWebResponse = myWebRequest.GetResponse();
            Console.WriteLine("The string has been posted.");
            Console.WriteLine("Please wait for the response...");

            Stream streamResponse = myWebResponse.GetResponseStream();
            StreamReader streamRead = new StreamReader( streamResponse );
            Char[] readBuff = new Char[256];
            int count = streamRead.Read( readBuff, 0, 256 );
            Console.WriteLine("\nThe contents of the HTML page are ");

            while (count > 0) 
                String outputData = new String(readBuff, 0, count);
                count = streamRead.Read(readBuff, 0, 256);

            // Close the Stream Object.

            // Release the HttpWebResponse Resource.
    private static void ReadCallback(IAsyncResult asynchronousResult)
            RequestState myRequestState =(RequestState) asynchronousResult.AsyncState;
            WebRequest myWebRequest = myRequestState.request;

            // End the Asynchronous request.
            Stream streamResponse = myWebRequest.EndGetRequestStream(asynchronousResult);

            // Create a string that is to be posted to the uri.
            Console.WriteLine("Please enter a string to be posted:");
            string postData = Console.ReadLine();
            // Convert the string into a byte array.
            byte[] byteArray = Encoding.UTF8.GetBytes(postData);

            // Write the data to the stream.
Imports System.Net
Imports System.IO
Imports System.Text
Imports System.Threading

Public Class RequestState
    ' This class stores the request state of the request.
    Public request As WebRequest
    Public Sub New()
        request = Nothing
    End Sub
End Class

Class WebRequest_BeginGetRequeststream
    Public Shared allDone As New ManualResetEvent(False)
    Shared Sub Main()
          ' Create a new request.
            Dim myWebRequest As WebRequest = WebRequest.Create("http://www.contoso.com/codesnippets/next.asp")
 ' Create an instance of the RequestState and assign 
            ' myWebRequest' to it's request field.
            Dim myRequestState As New RequestState()
            myRequestState.request = myWebRequest
            myWebRequest.ContentType = "application/x-www-form-urlencoded"

            ' Set the 'Method' property  to 'POST' to post data to a Uri.
            myRequestState.request.Method = "POST"
            ' Start the asynchronous 'BeginGetRequestStream' method call.
            Dim r As IAsyncResult = CType(myWebRequest.BeginGetRequestStream(AddressOf ReadCallback, myRequestState), IAsyncResult)
            ' Pause the current thread until the async operation completes.
            ' Send the Post and get the response.
            Dim myWebResponse As WebResponse = myWebRequest.GetResponse()
            Console.WriteLine(ControlChars.Cr + "The string has been posted.")
            Console.WriteLine("Please wait for the response....")
            Dim streamResponse As Stream = myWebResponse.GetResponseStream()
            Dim streamRead As New StreamReader(streamResponse)
            Dim readBuff(256) As [Char]
            Dim count As Integer = streamRead.Read(readBuff, 0, 256)
            Console.WriteLine(ControlChars.Cr + "The contents of the HTML page are ")
            While count > 0
                Dim outputData As New [String](readBuff, 0, count)
                count = streamRead.Read(readBuff, 0, 256)
            End While

           ' Close the Stream Object.
            ' Release the HttpWebResponse Resource.
    End Sub
    Private Shared Sub ReadCallback(asynchronousResult As IAsyncResult)
            Dim myRequestState As RequestState = CType(asynchronousResult.AsyncState, RequestState)
            Dim myWebRequest As WebRequest = myRequestState.request
            ' End the request.
            Dim streamResponse As Stream = myWebRequest.EndGetRequestStream(asynchronousResult)
            ' Create a string that is to be posted to the uri.
            Console.WriteLine(ControlChars.Cr + "Please enter a string to be posted:")
            Dim postData As String = Console.ReadLine()
            Dim encoder As New ASCIIEncoding()
            ' Convert  the string into a byte array.
            Dim byteArray As Byte() = Encoding.UTF8.GetBytes(postData)
            ' Write the data to the stream.
            streamResponse.Write(byteArray, 0, postData.Length)
            ' Allow the main thread to resume.
    End Sub
End Class


EndGetRequestStream方法會完成方法所啟動的非同步資料流程要求 BeginGetRequestStreamThe EndGetRequestStream method completes an asynchronous stream request that was started by the BeginGetRequestStream method.


若要避免垃圾收集的計時問題,請務必 Close 在呼叫後傳回的資料流程上呼叫方法,以關閉回應資料流程 GetResponseStream EndGetResponseTo avoid timing issues with garbage collection, be sure to close the response stream by calling the Close method on the stream returned by GetResponseStream after calling EndGetResponse.


WebRequest類別是 abstract 類別。The WebRequest class is an abstract class. WebRequest實例在執行時間的實際行為是由方法所傳回的子代類別所決定 WebRequest.CreateThe actual behavior of WebRequest instances at run time is determined by the descendant class returned by the WebRequest.Create method. 如需預設值和例外狀況的詳細資訊,請參閱下階類別的檔,例如 HttpWebRequestFileWebRequestFor more information about default values and exceptions, see the documentation for the descendant classes, such as HttpWebRequest and FileWebRequest.