共用方式為


HttpRequestMessageProperty 類別

定義

提供對 HTTP 要求的存取,以存取及回應透過 HTTP 通訊協定來提供給要求使用的其他資訊。

public ref class HttpRequestMessageProperty sealed : System::ServiceModel::Channels::IMessageProperty
public ref class HttpRequestMessageProperty sealed : System::ServiceModel::Channels::IMergeEnabledMessageProperty, System::ServiceModel::Channels::IMessageProperty
public ref class HttpRequestMessageProperty sealed
public sealed class HttpRequestMessageProperty : System.ServiceModel.Channels.IMessageProperty
public sealed class HttpRequestMessageProperty : System.ServiceModel.Channels.IMergeEnabledMessageProperty, System.ServiceModel.Channels.IMessageProperty
public sealed class HttpRequestMessageProperty
type HttpRequestMessageProperty = class
    interface IMessageProperty
type HttpRequestMessageProperty = class
    interface IMessageProperty
    interface IMergeEnabledMessageProperty
type HttpRequestMessageProperty = class
Public NotInheritable Class HttpRequestMessageProperty
Implements IMessageProperty
Public NotInheritable Class HttpRequestMessageProperty
Implements IMergeEnabledMessageProperty, IMessageProperty
Public NotInheritable Class HttpRequestMessageProperty
繼承
HttpRequestMessageProperty
實作
IMessageProperty System.ServiceModel.Channels.IMergeEnabledMessageProperty

範例

下列程式碼會示範如何在這個類別的執行個體內設定幾個屬性,並將此執行個體加入訊息中。

static Message BuildMessage()
{
    Message messageToSend = null;
    HttpRequestMessageProperty reqProps = new HttpRequestMessageProperty();
    reqProps.SuppressEntityBody = false;
    reqProps.Headers.Add("CustomHeader", "Test Value");
    reqProps.Headers.Add(HttpRequestHeader.UserAgent, "my user agent");

    try
    {
        messageToSend = Message.CreateMessage(MessageVersion.Soap11, "http://tempuri.org/IUntypedService/ProcessMessage", "Hello WCF");
    }
    catch (Exception e)
    {
        Console.WriteLine("got exception when sending message: " + e.ToString());
    }

    messageToSend.Properties[HttpRequestMessageProperty.Name] = reqProps;
    return messageToSend;
}
Private Shared Function BuildMessage() As Message
    Dim messageToSend As Message = Nothing
    Dim reqProps As New HttpRequestMessageProperty()
    reqProps.SuppressEntityBody = False
    reqProps.Headers.Add("CustomHeader", "Test Value")
    reqProps.Headers.Add(HttpRequestHeader.UserAgent, "my user agent")

    Try
        messageToSend = Message.CreateMessage(MessageVersion.Soap11, "http://tempuri.org/IUntypedService/ProcessMessage", "Hello WCF")
    Catch e As Exception
        Console.WriteLine("got exception when sending message: " & e.ToString())
    End Try

    messageToSend.Properties(HttpRequestMessageProperty.Name) = reqProps
    Return messageToSend
End Function

備註

這是一般用途的類別,可讓開發人員直接存取 HTTP 要求資訊,這些資訊可用於封裝 HTTP 特定的資訊。 使用這個類別的一個範例就是支援根據代表性狀態傳輸 (REST) 架構所實作的服務。

這個類別會啟用對以下案例的支援:

  • 讓用於每一個要求的 HTTP 動詞有所不同。

  • 允許根據要求來設定及查詢 HTTP 標頭 (索引鍵, 值) 組。

  • 允許為 HTTP 要求指定查詢字串。

這個類別可由 HttpTransportBindingElement 和相關類別使用。

如果是傳入訊息,這個屬性會加入至訊息中。

如果是傳出訊息,這個屬性會造成以下情況發生:

建構函式

HttpRequestMessageProperty()

初始化 HttpRequestMessageProperty 類別的新執行個體。

屬性

Headers

從 HTTP 要求取得 HTTP 標頭。

Method

取得或設定 HTTP 要求的 HTTP 動詞。

Name

取得與 HttpRequestMessageProperty 類別相關聯之訊息屬性的名稱。

QueryString

取得或設定 HTTP 要求的查詢字串。

SuppressEntityBody

取得或設定值,這個值指出是否會忽略訊息的本文以及只傳送標頭。

方法

Equals(Object)

判斷指定的物件是否等於目前的物件。

(繼承來源 Object)
GetHashCode()

做為預設雜湊函式。

(繼承來源 Object)
GetType()

取得目前執行個體的 Type

(繼承來源 Object)
MemberwiseClone()

建立目前 Object 的淺層複製。

(繼承來源 Object)
ToString()

傳回代表目前物件的字串。

(繼承來源 Object)

明確介面實作

IMergeEnabledMessageProperty.TryMergeWithProperty(Object)

提供對 HTTP 要求的存取,以存取及回應透過 HTTP 通訊協定來提供給要求使用的其他資訊。

IMessageProperty.CreateCopy()

建立並傳回目前物件的複本。

適用於