Udostępnij za pośrednictwem


HttpContent Klasa

Definicja

Klasa bazowa reprezentująca treść jednostki HTTP i nagłówki zawartości.

public ref class HttpContent abstract : IDisposable
public abstract class HttpContent : IDisposable
type HttpContent = class
    interface IDisposable
Public MustInherit Class HttpContent
Implements IDisposable
Dziedziczenie
HttpContent
Pochodne
Implementuje

Przykłady

Poniższy przykład przedstawia niestandardową implementację HttpContent. Niektóre metody, mimo że są zdefiniowane jako virtual, a nie abstract, powinny być nadal zastępowane w implementacji w celu uzyskania optymalnego zachowania.

public class MyContent : HttpContent
{
    private readonly string _data;
    public MyContent(string data)
    {
        _data = data;
    }

    // Minimal implementation needed for an HTTP request content,
    // i.e. a content that will be sent via HttpClient, contains the 2 following methods.
    protected override bool TryComputeLength(out long length)
    {
        // This content doesn't support pre-computed length and
        // the request will NOT contain Content-Length header.
        length = 0;
        return false;
    }

    // SerializeToStream* methods are internally used by CopyTo* methods
    // which in turn are used to copy the content to the NetworkStream.
    protected override Task SerializeToStreamAsync(Stream stream, TransportContext? context)
        => stream.WriteAsync(Encoding.UTF8.GetBytes(_data)).AsTask();

    // Override SerializeToStreamAsync overload with CancellationToken
    // if the content serialization supports cancellation, otherwise the token will be dropped.
    protected override Task SerializeToStreamAsync(Stream stream, TransportContext? context, CancellationToken cancellationToken)
        => stream.WriteAsync(Encoding.UTF8.GetBytes(_data), cancellationToken).AsTask();

    // In rare cases when synchronous support is needed, e.g. synchronous CopyTo used by HttpClient.Send,
    // implement synchronous version of SerializeToStream.
    protected override void SerializeToStream(Stream stream, TransportContext? context, CancellationToken cancellationToken)
        => stream.Write(Encoding.UTF8.GetBytes(_data));

    // CreateContentReadStream* methods, if implemented, will be used by ReadAsStream* methods
    // to get the underlying stream and avoid buffering.
    // These methods will not be used by HttpClient on a custom content.
    // They are for content receiving and HttpClient uses its own internal implementation for an HTTP response content.
    protected override Task<Stream> CreateContentReadStreamAsync()
        => Task.FromResult<Stream>(new MemoryStream(Encoding.UTF8.GetBytes(_data)));

    // Override CreateContentReadStreamAsync overload with CancellationToken
    // if the content serialization supports cancellation, otherwise the token will be dropped.
    protected override Task<Stream> CreateContentReadStreamAsync(CancellationToken cancellationToken)
        => Task.FromResult<Stream>(new MemoryStream(Encoding.UTF8.GetBytes(_data))).WaitAsync(cancellationToken);

    // In rare cases when synchronous support is needed, e.g. synchronous ReadAsStream,
    // implement synchronous version of CreateContentRead.
    protected override Stream CreateContentReadStream(CancellationToken cancellationToken)
        => new MemoryStream(Encoding.UTF8.GetBytes(_data));
}

Uwagi

Istnieje wiele zawartości HTTP, których można użyć. Należą do nich następujące elementy.

  1. ByteArrayContent — zawartość reprezentowana przez tablicę bajtów, służy również jako klasa bazowa dla StringContent i FormUrlEncodedContent.

  2. StringContent — zawartość oparta na ciągach domyślnie serializowana jako text/plainContent-Type z kodowaniem UTF-8.

  3. FormUrlEncodedContent — zawartość z krotkami nazwa/wartość serializowana jako application/x-www-form-urlencodedContent-Type.

  4. MultipartContent — zawartość, która może serializować wiele różnych obiektów HttpContent jako multipart/*Content-Type.

  5. JsonContent — zawartość, która domyślnie serializuje obiekty jako application/jsonContent-Type z kodowaniem UTF-8.

Klasa zawartości HTTP może być pochodna przez użytkownika w celu zapewnienia niestandardowej logiki serializacji zawartości.

Konstruktory

HttpContent()

Inicjuje nowe wystąpienie klasy HttpContent.

Właściwości

Headers

Pobiera nagłówki zawartości HTTP zdefiniowane w dokumencie RFC 2616.

Metody

CopyTo(Stream, TransportContext, CancellationToken)

Serializuje zawartość HTTP do strumienia bajtów i kopiuje ją do stream.

CopyToAsync(Stream)

Serializuj zawartość HTTP do strumienia bajtów i kopiuje ją do obiektu strumienia podanego jako parametr stream.

CopyToAsync(Stream, CancellationToken)

Serializuj zawartość HTTP do strumienia bajtów i kopiuje ją do obiektu strumienia podanego jako parametr stream.

CopyToAsync(Stream, TransportContext)

Serializuj zawartość HTTP do strumienia bajtów i kopiuje ją do obiektu strumienia podanego jako parametr stream.

CopyToAsync(Stream, TransportContext, CancellationToken)

Serializuj zawartość HTTP do strumienia bajtów i kopiuje ją do obiektu strumienia podanego jako parametr stream.

CreateContentReadStream(CancellationToken)

Serializuje zawartość HTTP do strumienia pamięci.

CreateContentReadStreamAsync()

Serializuj zawartość HTTP do strumienia pamięci jako operację asynchroniczną.

CreateContentReadStreamAsync(CancellationToken)

Serializuje zawartość HTTP do strumienia pamięci jako operację asynchroniczną.

Dispose()

Zwalnia niezarządzane zasoby i usuwa zasoby zarządzane używane przez HttpContent.

Dispose(Boolean)

Zwalnia niezarządzane zasoby używane przez HttpContent i opcjonalnie usuwa zasoby zarządzane.

Equals(Object)

Określa, czy określony obiekt jest równy bieżącemu obiektowi.

(Odziedziczone po Object)
GetHashCode()

Służy jako domyślna funkcja skrótu.

(Odziedziczone po Object)
GetType()

Pobiera Type bieżącego wystąpienia.

(Odziedziczone po Object)
LoadIntoBufferAsync()

Serializuj zawartość HTTP do buforu pamięci jako operację asynchroniczną.

LoadIntoBufferAsync(Int64)

Serializuj zawartość HTTP do buforu pamięci jako operację asynchroniczną.

MemberwiseClone()

Tworzy płytkią kopię bieżącego Object.

(Odziedziczone po Object)
ReadAsByteArrayAsync()

Serializuj zawartość HTTP do tablicy bajtów jako operację asynchroniczną.

ReadAsByteArrayAsync(CancellationToken)

Serializuj zawartość HTTP do tablicy bajtów jako operację asynchroniczną.

ReadAsStream()

Serializuje zawartość HTTP i zwraca strumień reprezentujący zawartość.

ReadAsStream(CancellationToken)

Serializuje zawartość HTTP i zwraca strumień reprezentujący zawartość.

ReadAsStreamAsync()

Serializowanie zawartości HTTP i zwracanie strumienia reprezentującego zawartość jako operację asynchroniczną.

ReadAsStreamAsync(CancellationToken)

Serializowanie zawartości HTTP i zwracanie strumienia reprezentującego zawartość jako operację asynchroniczną.

ReadAsStringAsync()

Serializuj zawartość HTTP do ciągu jako operację asynchroniczną.

ReadAsStringAsync(CancellationToken)

Serializuj zawartość HTTP do ciągu jako operację asynchroniczną.

SerializeToStream(Stream, TransportContext, CancellationToken)

Po zastąpieniu w klasie pochodnej serializuje zawartość HTTP do strumienia. W przeciwnym razie zgłasza NotSupportedException.

SerializeToStreamAsync(Stream, TransportContext)

Serializuj zawartość HTTP do strumienia jako operację asynchroniczną.

SerializeToStreamAsync(Stream, TransportContext, CancellationToken)

Serializuj zawartość HTTP do strumienia jako operację asynchroniczną.

ToString()

Zwraca ciąg reprezentujący bieżący obiekt.

(Odziedziczone po Object)
TryComputeLength(Int64)

Określa, czy zawartość HTTP ma prawidłową długość w bajtach.

Metody rozszerzania

ReadFromJsonAsAsyncEnumerable<TValue>(HttpContent, JsonSerializerOptions, CancellationToken)

Odczytuje zawartość HTTP i zwraca wartość, która wynika z deserializacji zawartości jako kodu JSON w operacji asynchronicznego wyliczania.

ReadFromJsonAsAsyncEnumerable<TValue>(HttpContent, JsonTypeInfo<TValue>, CancellationToken)

Odczytuje zawartość HTTP i zwraca wartość, która wynika z deserializacji zawartości jako kodu JSON w operacji asynchronicznego wyliczania.

ReadFromJsonAsAsyncEnumerable<TValue>(HttpContent, CancellationToken)

Odczytuje zawartość HTTP i zwraca wartość, która wynika z deserializacji zawartości jako kodu JSON w operacji asynchronicznego wyliczania.

ReadFromJsonAsync(HttpContent, Type, JsonSerializerOptions, CancellationToken)

Odczytuje zawartość HTTP i zwraca wartość, która wynika z deserializacji zawartości jako kodu JSON w operacji asynchronicznej.

ReadFromJsonAsync(HttpContent, Type, JsonSerializerContext, CancellationToken)

Odczytuje zawartość HTTP i zwraca wartość, która wynika z deserializacji zawartości jako kodu JSON w operacji asynchronicznej.

ReadFromJsonAsync(HttpContent, Type, CancellationToken)

Odczytuje zawartość HTTP i zwraca wartość, która wynika z deserializacji zawartości jako kodu JSON w operacji asynchronicznej.

ReadFromJsonAsync<T>(HttpContent, JsonSerializerOptions, CancellationToken)

Odczytuje zawartość HTTP i zwraca wartość, która wynika z deserializacji zawartości jako kodu JSON w operacji asynchronicznej.

ReadFromJsonAsync<T>(HttpContent, JsonTypeInfo<T>, CancellationToken)

Odczytuje zawartość HTTP i zwraca wartość, która wynika z deserializacji zawartości jako kodu JSON w operacji asynchronicznej.

ReadFromJsonAsync<T>(HttpContent, CancellationToken)

Odczytuje zawartość HTTP i zwraca wartość, która wynika z deserializacji zawartości jako kodu JSON w operacji asynchronicznej.

Dotyczy