Sdílet prostřednictvím


HttpListenerRequest Třída

Definice

Popisuje příchozí požadavek HTTP na HttpListener objekt. Tato třída se nemůže dědit.

public ref class HttpListenerRequest sealed
public sealed class HttpListenerRequest
type HttpListenerRequest = class
Public NotInheritable Class HttpListenerRequest
Dědičnost
HttpListenerRequest

Příklady

Následující příklad kódu ukazuje, jak přijmout a reagovat na HttpListenerRequest.

// This example requires the System and System.Net namespaces.
public static void SimpleListenerExample(string[] prefixes)
{
    if (!HttpListener.IsSupported)
    {
        Console.WriteLine ("Windows XP SP2 or Server 2003 is required to use the HttpListener class.");
        return;
    }
    // URI prefixes are required,
    // for example "http://contoso.com:8080/index/".
    if (prefixes == null || prefixes.Length == 0)
      throw new ArgumentException("prefixes");

    // Create a listener.
    HttpListener listener = new HttpListener();
    // Add the prefixes.
    foreach (string s in prefixes)
    {
        listener.Prefixes.Add(s);
    }
    listener.Start();
    Console.WriteLine("Listening...");
    // Note: The GetContext method blocks while waiting for a request.
    HttpListenerContext context = listener.GetContext();
    HttpListenerRequest request = context.Request;
    // Obtain a response object.
    HttpListenerResponse response = context.Response;
    // Construct a response.
    string responseString = "<HTML><BODY> Hello world!</BODY></HTML>";
    byte[] buffer = System.Text.Encoding.UTF8.GetBytes(responseString);
    // Get a response stream and write the response to it.
    response.ContentLength64 = buffer.Length;
    System.IO.Stream output = response.OutputStream;
    output.Write(buffer,0,buffer.Length);
    // You must close the output stream.
    output.Close();
    listener.Stop();
}
Public Shared Sub SimpleListenerExample(prefixes As String())
    If Not HttpListener.IsSupported Then
        Console.WriteLine("Windows XP SP2 or Server 2003 is required to use the HttpListener class.")
        Return
    End If
    ' URI prefixes are required,
    ' for example "http://contoso.com:8080/index/".
    If prefixes Is Nothing Or prefixes.Length = 0 Then
        Throw New ArgumentException("prefixes")
    End If

    ' Create a listener
    Dim listener = New HttpListener()

    For Each s As String In prefixes
        listener.Prefixes.Add(s)
    Next
    listener.Start()
    Console.WriteLine("Listening...")
    ' Note: The GetContext method blocks while waiting for a request.
    Dim context As HttpListenerContext = listener.GetContext()
    Console.WriteLine("Listening...")
    ' Obtain a response object
    Dim request As HttpListenerRequest = context.Request
    ' Construct a response.
    Dim response As HttpListenerResponse = context.Response
    Dim responseString As String = "<HTML><BODY> Hello world!</BODY></HTML>"
    Dim buffer As Byte() = System.Text.Encoding.UTF8.GetBytes(responseString)
    ' Get a response stream and write the response to it.
    response.ContentLength64 = buffer.Length
    Dim output As System.IO.Stream = response.OutputStream
    output.Write(buffer, 0, buffer.Length)
    'You must close the output stream.
    output.Close()
    listener.Stop()
End Sub

Poznámky

Když klient odešle požadavek na identifikátor URI (Uniform Resource Identifier) zpracovávaný objektem HttpListener , HttpListener poskytuje HttpListenerContext objekt objekt , který obsahuje informace o odesílateli, požadavku a odpovědi, která je odeslána klientovi. Vlastnost HttpListenerContext.Request vrátí HttpListenerRequest objekt, který popisuje požadavek.

Objekt HttpListenerRequest obsahuje informace o požadavku, jako je řetězec požadavku HttpMethod , UserAgent řetězec a data textu požadavku (viz InputStream vlastnost ).

Pokud chcete na požadavek odpovědět, musíte získat přidruženou odpověď pomocí Response vlastnosti .

Vlastnosti

AcceptTypes

Získá typy MIME akceptované klientem.

ClientCertificateError

Získá kód chyby, který identifikuje problém s X509Certificate klientem.

ContentEncoding

Získá kódování obsahu, které lze použít s daty odesílanými s požadavkem.

ContentLength64

Získá délku těla dat zahrnutých v požadavku.

ContentType

Získá typ MIME těla dat zahrnutých v požadavku.

Cookies

Získá soubory cookie odeslané s požadavkem.

HasEntityBody

Boolean Získá hodnotu, která označuje, zda má požadavek přidružená data těla.

Headers

Získá kolekci dvojic název/hodnota hlavičky odeslané v požadavku.

HttpMethod

Získá metodu HTTP určenou klientem.

InputStream

Získá datový proud, který obsahuje data těla odeslaná klientem.

IsAuthenticated

Boolean Získá hodnotu, která označuje, zda klient odesílající tento požadavek je ověřen.

IsLocal

Boolean Získá hodnotu, která označuje, zda je požadavek odeslán z místního počítače.

IsSecureConnection

Boolean Získá hodnotu, která označuje, zda připojení TCP použité k odeslání požadavku používá protokol SSL (Secure Sockets Layer).

IsWebSocketRequest

Boolean Získá hodnotu, která označuje, zda připojení TCP byl požadavek WebSocket.

KeepAlive

Boolean Získá hodnotu, která označuje, zda klient požaduje trvalé připojení.

LocalEndPoint

Získá IP adresu serveru a číslo portu, na který je požadavek směrován.

ProtocolVersion

Získá verzi PROTOKOLU HTTP používanou žádajícím klientem.

QueryString

Získá řetězec dotazu zahrnutý v požadavku.

RawUrl

Získá informace adresy URL (bez hostitele a portu) požadované klientem.

RemoteEndPoint

Získá IP adresu klienta a číslo portu, ze kterého požadavek pochází.

RequestTraceIdentifier

Získá identifikátor požadavku příchozího požadavku HTTP.

ServiceName

Získá název poskytovatele služby (SPN), který klient odeslal v požadavku.

TransportContext

TransportContext Získá pro požadavek klienta.

Url

Uri Získá objekt požadovaný klientem.

UrlReferrer

Získá identifikátor URI (Uniform Resource Identifier) prostředku, který odkázal klienta na server.

UserAgent

Získá uživatelský agent prezentovaný klientem.

UserHostAddress

Získá IP adresu serveru a číslo portu, na který je požadavek směrován.

UserHostName

Získá název DNS a pokud je zadáno číslo portu určené klientem.

UserLanguages

Získá přirozené jazyky, které jsou upřednostňované pro odpověď.

Metody

BeginGetClientCertificate(AsyncCallback, Object)

Zahájí asynchronní požadavek na certifikát X.509 v.3 klienta.

EndGetClientCertificate(IAsyncResult)

Ukončí asynchronní požadavek na certifikát X.509 v.3 klienta.

Equals(Object)

Určí, zda se zadaný objekt rovná aktuálnímu objektu.

(Zděděno od Object)
GetClientCertificate()

Načte certifikát X.509 v.3 klienta.

GetClientCertificateAsync()

Načte certifikát X.509 v.3 klienta jako asynchronní operaci.

GetHashCode()

Slouží jako výchozí hashovací funkce.

(Zděděno od Object)
GetType()

Type Získá z aktuální instance.

(Zděděno od Object)
MemberwiseClone()

Vytvoří mělkou kopii aktuálního Objectsouboru .

(Zděděno od Object)
ToString()

Vrátí řetězec, který představuje aktuální objekt.

(Zděděno od Object)

Platí pro

Viz také