Sdílet prostřednictvím


HttpWebRequest.GetResponse Metoda

Definice

Vrátí odpověď z internetového prostředku.

public:
 override System::Net::WebResponse ^ GetResponse();
public override System.Net.WebResponse GetResponse ();
override this.GetResponse : unit -> System.Net.WebResponse
Public Overrides Function GetResponse () As WebResponse

Návraty

WebResponse obsahující odpověď z internetového prostředku.

Výjimky

Stream se již používá předchozím voláním BeginGetResponse(AsyncCallback, Object).

-nebo-

TransferEncoding je nastavena na hodnotu a SendChunked je false.

Method je FUNKCE GET nebo HEAD a ContentLength je větší nebo rovna nule nebo SendChunked je true.

-nebo-

KeepAlive je true, AllowWriteStreamBuffering je false, ContentLength je -1, SendChunked je falsea Method je POST nebo PUT.

-nebo-

HttpWebRequest má tělo entity, ale GetResponse() metoda je volána bez volání metody GetRequestStream().

-nebo-

ContentLength je větší než nula, ale aplikace nezapisuje všechna slíbená data.

Validátor mezipaměti požadavku uvedl, že odpověď pro tento požadavek může být obsluhována z mezipaměti; tento požadavek však zahrnuje data, která se mají odeslat na server. Požadavky, které odesílají data, nesmí mezipaměť používat. K této výjimce může dojít, pokud používáte vlastní validátor mezipaměti, který je nesprávně implementován.

Abort() byl dříve volána.

-nebo-

Vypršel časový limit požadavku.

-nebo-

Při zpracování požadavku došlo k chybě.

Příklady

Následující příklad kódu získá odpověď pro požadavek.

#using <System.dll>

using namespace System;
using namespace System::Net;
using namespace System::Text;
using namespace System::IO;

// Specify the URL to receive the request.
int main()
{
   array<String^>^args = Environment::GetCommandLineArgs();
   HttpWebRequest^ request = dynamic_cast<HttpWebRequest^>(WebRequest::Create(args[1]));

   // Set some reasonable limits on resources used by this request
   request->MaximumAutomaticRedirections = 4;
   request->MaximumResponseHeadersLength = 4;

   // Set credentials to use for this request.
   request->Credentials = CredentialCache::DefaultCredentials;
   HttpWebResponse^ response = dynamic_cast<HttpWebResponse^>(request->GetResponse());
   Console::WriteLine("Content length is {0}", response->ContentLength);
   Console::WriteLine("Content type is {0}", response->ContentType);

   // Get the stream associated with the response.
   Stream^ receiveStream = response->GetResponseStream();

   // Pipes the stream to a higher level stream reader with the required encoding format.
   StreamReader^ readStream = gcnew StreamReader(receiveStream, Encoding::UTF8);
   Console::WriteLine("Response stream received.");
   Console::WriteLine(readStream->ReadToEnd());
   response->Close();
   readStream->Close();
}

/*
The output from this example will vary depending on the value passed into Main
but will be similar to the following:

Content length is 1542
Content type is text/html; charset=utf-8
Response stream received.
<html>
...
</html>

*/
using System;
using System.Net;
using System.Text;
using System.IO;

    public class Test
    {
        // Specify the URL to receive the request.
        public static void Main (string[] args)
        {
            HttpWebRequest request = (HttpWebRequest)WebRequest.Create(args[0]);

            // Set some reasonable limits on resources used by this request
            request.MaximumAutomaticRedirections = 4;
            request.MaximumResponseHeadersLength = 4;
            // Set credentials to use for this request.
            request.Credentials = CredentialCache.DefaultCredentials;
            HttpWebResponse response = (HttpWebResponse)request.GetResponse();

            Console.WriteLine("Content length is {0}", response.ContentLength);
            Console.WriteLine("Content type is {0}", response.ContentType);

            // Get the stream associated with the response.
            Stream receiveStream = response.GetResponseStream();

            // Pipes the stream to a higher level stream reader with the required encoding format.
            StreamReader readStream = new StreamReader(receiveStream, Encoding.UTF8);

            Console.WriteLine("Response stream received.");
            Console.WriteLine(readStream.ReadToEnd());
            response.Close();
            readStream.Close();
        }
    }

/*
The output from this example will vary depending on the value passed into Main
but will be similar to the following:

Content length is 1542
Content type is text/html; charset=utf-8
Response stream received.
<html>
...
</html>

*/
Imports System.Net
Imports System.Text
Imports System.IO


    Public Class Test

        ' Specify the URL to receive the request.
        Public Shared Sub Main(ByVal args() As String)
        Dim request As HttpWebRequest = CType(WebRequest.Create(args(0)), HttpWebRequest)


        ' Set some reasonable limits on resources used by this request
        request.MaximumAutomaticRedirections = 4
        request.MaximumResponseHeadersLength = 4

        ' Set credentials to use for this request.
        request.Credentials = CredentialCache.DefaultCredentials

        Dim response As HttpWebResponse = CType(request.GetResponse(), HttpWebResponse)

        Console.WriteLine("Content length is {0}", response.ContentLength)
        Console.WriteLine("Content type is {0}", response.ContentType)

        ' Get the stream associated with the response.
        Dim receiveStream As Stream = response.GetResponseStream()

        ' Pipes the stream to a higher level stream reader with the required encoding format. 
        Dim readStream As New StreamReader(receiveStream, Encoding.UTF8)

        Console.WriteLine("Response stream received.")
        Console.WriteLine(readStream.ReadToEnd())
        response.Close()
        readStream.Close()
    End Sub
End Class
'
'The output from this example will vary depending on the value passed into Main 
'but will be similar to the following:
'
'Content length is 1542
'Content type is text/html; charset=utf-8
'Response stream received.
'...
'
'

Poznámky

Opatrnost

WebRequest, HttpWebRequest, ServicePointa WebClient jsou zastaralé a neměli byste je používat pro nový vývoj. Místo toho použijte HttpClient.

Metoda GetResponse vrátí objekt WebResponse, který obsahuje odpověď z internetového prostředku. Vrácená skutečná instance je HttpWebResponsea může být typecast této třídě pro přístup k vlastnostem specifických pro HTTP.

ProtocolViolationException je vyvolán v několika případech, když jsou vlastnosti nastavené na HttpWebRequest třídy konfliktní. K této výjimce dochází v případě, že aplikace nastaví vlastnost ContentLength a vlastnost SendChunked na truea pak odešle požadavek HTTP GET. K této výjimce dochází v případě, že se aplikace pokusí odeslat blok dat na server, který podporuje pouze protokol HTTP 1.0, kde to není podporováno. K této výjimce dochází, pokud se aplikace pokusí odeslat data bez nastavení vlastnosti ContentLength nebo SendChunked je false při zakázání ukládání do vyrovnávací paměti a při zachování připojení (vlastnost KeepAlive je true).

Opatrnost

Pokud chcete datový proud zavřít a uvolnit připojení, musíte volat metodu Close. Pokud to neuděláte, může dojít k tomu, že aplikace dojde k výpadku připojení.

Při použití metody POST musíte získat stream požadavku, zapisovat data, která se mají publikovat, a zavřít stream. Tato metoda blokuje čekání na publikování obsahu; Pokud není nastavený časový limit a nezadáte obsah, volající vlákno bude blokovat po neomezenou dobu.

Poznámka

Více volání GetResponse vrátit stejný objekt odpovědi; požadavek se znovu nesudí.

Poznámka

Vaše aplikace nemůže kombinovat synchronní a asynchronní metody pro konkrétní požadavek. Pokud voláte metodu GetRequestStream, musíte k načtení odpovědi použít metodu GetResponse.

Poznámka

Pokud dojde k vyvolání WebException, pomocí vlastností Response a Status výjimky určete odpověď ze serveru.

Poznámka

Tento člen vypíše informace o trasování, když ve své aplikaci povolíte trasování sítě. Další informace naleznete v tématu Trasování sítě v rozhraní .NET Framework.

Poznámka

Z bezpečnostních důvodů jsou soubory cookie ve výchozím nastavení zakázané. Pokud chcete soubory cookie používat, povolte soubory cookie pomocí vlastnosti CookieContainer.

Platí pro

Viz také