HttpListenerRequest Třída
Definice
Důležité
Některé informace platí pro předběžně vydaný produkt, který se může zásadně změnit, než ho výrobce nebo autor vydá. Microsoft neposkytuje žádné záruky, výslovné ani předpokládané, týkající se zde uváděných informací.
Popisuje příchozí požadavek HTTP objektu HttpListener . Tuto třídu nelze zdě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řijímat 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), který HttpListener zpracovává objekt, poskytuje HttpListenerContext objekt, HttpListener který obsahuje informace o odesílateli, požadavku a odpovědi odeslané klientovi. Vlastnost HttpListenerContext.Request vrátí HttpListenerRequest objekt, který popisuje požadavek.
Objekt HttpListenerRequest obsahuje informace o požadavku, například řetězec požadavku HttpMethod , UserAgent řetězec a základní data požadavku (viz InputStream vlastnost).
Chcete-li odpovědět na žádost, musíte získat přidruženou odpověď pomocí Response vlastnosti.
Vlastnosti
| Name | Description |
|---|---|
| AcceptTypes |
Získá typy MIME přijaté klientem. |
| ClientCertificateError |
Získá kód chyby, který identifikuje problém s X509Certificate poskytnutým 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 textových dat zahrnutých v požadavku. |
| ContentType |
Získá typ MIME základní data zahrnutá v požadavku. |
| Cookies |
Získá soubory cookie odeslané s žádostí. |
| HasEntityBody |
Boolean Získá hodnotu, která určuje, zda požadavek má 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 základní data odesílaná 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á urč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 bylo připojení TCP požadavek WebSocket. |
| KeepAlive |
Boolean Získá hodnotu, která určuje, zda klient požaduje trvalé připojení. |
| LocalEndPoint |
Získá IP adresu serveru a číslo portu, na které se požadavek směruje. |
| ProtocolVersion |
Získá verzi HTTP používanou žádajícím klientem. |
| QueryString |
Získá řetězec dotazu zahrnutý v požadavku. |
| RawUrl |
Získá informace o adrese 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 zprostředkovatele služeb (SPN), který klient odeslal na žádost. |
| TransportContext |
TransportContext Získá požadavek klienta. |
| Url |
Uri Získá objekt požadovaný klientem. |
| UrlReferrer |
Získá identifikátor URI (Uniform Resource Identifier) prostředku, který odkazuje klienta na server. |
| UserAgent |
Získá uživatelského agenta prezentovaného klientem. |
| UserHostAddress |
Získá IP adresu serveru a číslo portu, na které se požadavek směruje. |
| UserHostName |
Získá název DNS a v případě zadání číslo portu určeného klientem. |
| UserLanguages |
Získá přirozené jazyky, které jsou upřednostňované pro odpověď. |
Metody
| Name | Description |
|---|---|
| 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čuje, zda je zadaný objekt roven 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í funkce hash. (Zděděno od Object) |
| GetType() |
Získá Type aktuální instance. (Zděděno od Object) |
| MemberwiseClone() |
Vytvoří mělkou kopii aktuálního Object. (Zděděno od Object) |
| ToString() |
Vrátí řetězec, který představuje aktuální objekt. (Zděděno od Object) |