共用方式為


<netHttpBinding>

代表 Windows Communication Foundation (WCF) 服務可用來設定和公開能夠透過 HTTP 通訊之端點的繫結。 與雙工合約搭配使用時,將會使用 Web 通訊端,否則使用 HTTP。

<configuration>
  <system.serviceModel>
    <bindings>
      <netHttpBinding>

Syntax

<netHttpBinding>
  <binding allowCookies="Boolean"
           bypassProxyOnLocal="Boolean"
           closeTimeout="TimeSpan"
           hostNameComparisonMode="StrongWildCard/Exact/WeakWildcard"
           maxBufferPoolSize="Integer"
           maxBufferSize="Integer"
           maxReceivedMessageSize="Integer"
           messageEncoding="Binary/Text/Mtom"
           name="String"
           openTimeout="TimeSpan"
           proxyAddress="URI"
           receiveTimeout="TimeSpan"
           sendTimeout="TimeSpan"
           textEncoding="UnicodeFffeTextEncoding/Utf16TextEncoding/Utf8TextEncoding"
           transferMode="Buffered/Streamed/StreamedRequest/StreamedResponse"
           useDefaultWebProxy="Boolean">
    <security mode="None/Transport/Message/TransportWithMessageCredential/TransportCredentialOnly">
      <transport clientCredentialType="None/Basic/Digest/Ntlm/Windows/Certificate"
                 proxyCredentialType="None/Basic/Digest/Ntlm/Windows"
                 realm="string" />
      <message algorithmSuite="Basic128/Basic192/Basic256/Basic128Rsa15/Basic256Rsa15/TripleDes/TripleDesRsa15/Basic128Sha256/Basic192Sha256/TripleDesSha256/Basic128Sha256Rsa15/Basic192Sha256Rsa15/Basic256Sha256Rsa15/TripleDesSha256Rsa15"
               clientCredentialType="UserName/Certificate" />
    </security>
    <readerQuotas maxArrayLength="Integer"
                  maxBytesPerRead="Integer"
                  maxDepth="Integer"
                  maxNameTableCharCount="Integer"
                  maxStringContentLength="Integer" />
  </binding>
</netHttpBinding>

類型

Type

屬性和項目

下列章節說明屬性、子元素和父元素。

屬性

屬性 描述
allowCookies 布林值,表示用戶端是否接受 Cookie 並在未來要求時傳播 Cookie。 預設為 false

當您與使用 Cookie 的 ASMX Web 服務互動時,可以使用這個屬性。 如此一來,從伺服器傳回的 Cookie 就一定會自動複製到該服務未來所有的用戶端要求。
bypassProxyOnLocal 布林值,指出本機位址是否略過 Proxy 伺服器。 預設值為 false

如果網際網路資源有本機位址,則此資源為本機資源。 本機位址是指位於相同電腦、區域 LAN 或內部網路的位址,在語法上沒有句號 (.),如同 URI http://webserver/http://localhost/ 那樣。

設定這個屬性可決定以 BasicHttpBinding 設定的端點在存取本機資源時,是否使用 Proxy 伺服器。 如果這個屬性為 true,則所有對本機網際網路資源的要求都不會使用 Proxy 伺服器。 當這個屬性設定為 true 時,如果想要讓用戶端在與相同電腦上的服務進行交談時通過 Proxy,請使用主機名稱 (而非 localhost)。

當這個屬性設定為 false 時,則所有的網際網路要求都會通過 Proxy 伺服器。
closeTimeout TimeSpan 值,指定提供用來讓關閉作業完成的時間間隔。 這個值應該大於或等於 Zero。 預設為 00:01:00。
hostNameComparisonMode 指定用於剖析 URI 的 HTTP 主機名稱比較模式。 這個屬性的型別為 HostNameComparisonMode,表示比對 URI 時此主機名稱是否會用來取用服務。 預設值為 StrongWildcard,表示比對時忽略主機名稱。
maxBufferPoolSize 整數值,指定配置供從通道接收訊息之訊息緩衝區管理員使用的最大記憶體量。 預設值為 524288 (0x80000) 位元組。

緩衝區管理員會利用緩衝區集區,將使用緩衝區的成本降至最低。 當訊息從通道送出時,服務將需要緩衝區來處理訊息。 如果緩衝區集區中沒有足夠的記憶體可以處理訊息負載,緩衝區管理員就必須從 CLR 堆積配置額外的記憶體,進而增加記憶體回收負荷。 從 CLR 記憶體回收堆積所產生的大量配置表示緩衝區集區太小,而提高這個屬性指定的限制來提供較大的配置,便可改善效能。
maxBufferSize 整數值,指定儲存訊息之緩衝區的大小上限 (以位元組為單位)。在為此繫結設定的端點處理訊息時,可以將訊息儲存在緩衝區中。 預設值為 65,536 位元組。
maxReceivedMessageSize 正整數,定義在使用此繫結設定之通道上可以接收的訊息大小上限 (以位元組為單位,包括標頭)。 如果對收件者而言訊息太大,寄件者便會收到 SOAP 錯誤。 收件者會捨棄訊息,然後在追蹤記錄檔中建立此事件的項目。 預設值為 65,536 個位元組。
messageEncoding 定義用來對 SOAP 訊息進行編碼的編碼器。 有效值如下:

- Text:使用文字訊息編碼器。
- Mtom:使用 Message Transmission Organization Mechanism 1.0 (MTOM) 編碼器。

預設為 Text。 此屬性的型別為 WSMessageEncoding
name 包含繫結之組態名稱的字串。 這個值應該是唯一的,因為它會當做繫結的識別使用。 從 .NET Framework 4 開始,不需要有名稱的系結和行為。 如需預設設定、無名稱繫結與行為的詳細資訊,請參閱簡化的設定 (機器翻譯)WCF 服務的簡化設定 (機器翻譯)
openTimeout TimeSpan 值,指定提供用來讓開啟作業完成的時間間隔。 這個值應該大於或等於 Zero。 預設為 00:01:00。
proxyAddress 包含 HTTP Proxy 位址的 URI。 如果 useSystemWebProxy 設定為 true,則這個設定必須為 null。 預設值為 null
receiveTimeout TimeSpan 值,指定接收作業完成其作業之時間間隔。 這個值應該大於或等於 Zero。 預設為 00:10:00。
sendTimeout TimeSpan 值,指定提供用來讓傳送作業完成的時間間隔。 這個值應該大於或等於 Zero。 預設為 00:01:00。
textEncoding 設定要在繫結上發出訊息時使用的字元集編碼方式。 有效值如下:

- BigEndianUnicode:Unicode BigEndian 編碼方式。
- Unicode:16 位元編碼方式。
- UTF8:8 位元編碼方式

預設值為 UTF8。 此屬性的型別為 Encoding
transferMode 有效的 TransferMode 值,指定進行要求或回應時,訊息是經過緩衝處理或資料流處理。
useDefaultWebProxy 布林值,指定是否應使用系統自動設定的 HTTP Proxy (如果有的話)。 預設值為 true

子元素

元素 描述
<security> 定義繫結的安全性設定。 此項目的型別為 BasicHttpSecurityElement
<readerQuotas> 定義 SOAP 訊息複雜度的條件約束,而這些條件約束可由以此繫結所設定的端點處理。 此項目的型別為 XmlDictionaryReaderQuotasElement

父項目

元素 描述
<bindings> 這個項目會保存標準和自訂繫結的集合。

備註

NetHttpBinding 使用 HTTP 做為傳送訊息的傳輸。 與雙工合約搭配使用時,將會使用 Web 通訊端。 與要求-回覆合約搭配使用時,NetHttpBinding 的行為就像具有二進位編碼器的 BasicHttpBinding。

安全性預設是關閉的,但是可以透過將<安全性>子項目的模式屬性設定為 None 以外的任何值來新增安全性設定。 根據預設,它使用「文字」訊息編碼和 UTF-8 文字編碼。

範例 1

下列範例示範 NetHttpBinding 的使用方式,它利用第一代和第二代 Web 服務來提供 HTTP 通訊和最大的互通性。 用戶端和服務的組態檔中會指定繫結。 繫結型別是使用 binding 項目的 <endpoint> 屬性所指定的。 如果您要設定基本繫結,並變更其部分設定,則必須定義繫結組態。 端點必須使用 bindingConfiguration 項目的 <endpoint> 屬性來按照名稱參考繫結組態,如下列服務的組態程式碼所示。

<system.serviceModel>
  <services>
    <service type="Microsoft.ServiceModel.Samples.CalculatorService"
             behaviorConfiguration="CalculatorServiceBehavior">
      <endpoint address=""
                binding="netHttpBinding"
                bindingConfiguration="Binding1"
                contract="Microsoft.ServiceModel.Samples.ICalculator" />
    </service>
  </services>
  <bindings>
    <netHttpBinding>
      <binding name="Binding1"
               hostNameComparisonMode="StrongWildcard"
               receiveTimeout="00:10:00"
               sendTimeout="00:10:00"
               openTimeout="00:10:00"
               closeTimeout="00:10:00"
               maxReceivedMessageSize="65536"
               maxBufferSize="65536"
               maxBufferPoolSize="524288"
               transferMode="Buffered"
               messageEncoding="Binary"
               textEncoding="utf-8"
               bypassProxyOnLocal="false"
               useDefaultWebProxy="true">
        <security mode="None" />
      </binding>
    </netHttpBinding>
  </bindings>
</system.serviceModel>

範例 2

從 .NET Framework 4 開始,不需要有名稱的系結和行為。 前一個範例的功能可以藉由從端點位址移除 bindingConfiguration 以及從繫結移除名稱的方式達成。

<system.serviceModel>
  <services>
    <service type="Microsoft.ServiceModel.Samples.CalculatorService"
             behaviorConfiguration="CalculatorServiceBehavior">
      <endpoint address=""
                binding="netHttpBinding"
                contract="Microsoft.ServiceModel.Samples.ICalculator" />
    </service>
  </services>
  <bindings>
    <netHttpBinding>
      <binding hostNameComparisonMode="StrongWildcard"
               receiveTimeout="00:10:00"
               sendTimeout="00:10:00"
               openTimeout="00:10:00"
               closeTimeout="00:10:00"
               maxReceivedMessageSize="65536"
               maxBufferSize="65536"
               maxBufferPoolSize="524288"
               transferMode="Buffered"
               messageEncoding="Binary"
               textEncoding="utf-8"
               bypassProxyOnLocal="false"
               useDefaultWebProxy="true">
        <security mode="None" />
      </binding>
    </netHttpBinding>
  </bindings>
</system.serviceModel>

如需預設設定、無名稱繫結與行為的詳細資訊,請參閱簡化的組態 (部分機器翻譯) 與WCF 服務的簡化組態 (部分機器翻譯)。

另請參閱