共用方式為


如何設定 WCF-NetTcp 接收位置

您可以用程式設計方式或使用 BizTalk 管理主控台來設定 WCF-NetTcp 接收位置。

設定屬性

「BizTalk 總管物件模型」可讓您以程式設計的方式建立和設定接收位置。 BizTalk Explorer 物件模型會公開具有TransportTypeData讀取/寫入屬性的IReceiveLocation接收位置組態介面。 這項屬性會以 XML 字串之成對的名稱-數值格式接受 WCF-NetTcp 接收位置組態屬性包。 若要在 BizTalk Explorer 物件模型中設定此屬性,您必須設定IReceiveLocation介面的InboundTransportLocation屬性。

IReceiveLocation介面的TransportTypeData屬性不需要設定。 若沒有設定此屬性,WCF-NetTcp 配接器就會使用 WCF-NetTcp 接收位置組態預設值,如下表所示。

下表將列出您可以在 BizTalk 總管物件模型中針對 WCF-NetTcp 接收位置設定的組態屬性。

屬性名稱 類型 描述
身分識別 XML BLOB

範例:

<身分識別>

<userPrincipalName value=「 username@contoso.com 」 />

</身份>
指定此接收位置所提供服務的識別。 可針對 Identity 屬性指定的值會根據安全性設定而有所不同。 這些設定可讓用戶端驗證此接收位置。 在用戶端與服務之間的交握程序中,Windows Communication Foundation (WCF) 基礎結構可確保預期之服務的識別能夠與這個項目的值相符。

預設為空字串。
OpenTimeout System.TimeSpan 指定時間值,表示可供完成通道開啟作業的時間間隔。

預設值:00:01:00
SendTimeout System.TimeSpan 指定時間值,表示可供完成傳送作業的時間間隔。 如果您使用要求-回應接收埠,這個值會指定完成整個互動的時間長度,即使服務傳回很大的訊息也是如此。

預設值:00:01:00
CloseTimeout System.TimeSpan 指定時間值,表示可供完成通道關閉作業的時間間隔。

預設值:00:01:00
MaxReceivedMessageSize 整數 指定訊息的大小上限,以位元組為單位, (包括可在網路接收的標頭) 。 訊息的大小受限於配置給每個訊息的記憶體數量。 您可以使用這個屬性來限制遭受拒絕服務 (DoS) 攻擊的風險程度。

WCF-NetTcp 配接器會利用緩衝傳輸模式中的 NetTcpBinding 類別來與端點通訊。 針對緩衝傳輸模式, NetTcpBinding.MaxBufferSize 屬性一律等於此屬性的值。

預設值:65536
EnableTransaction Boolean 指定是否使用來自用戶端的交易,將訊息提交至 MessageBox 資料庫。 如果此屬性設定為 True,則需要用戶端使用 TransactionProtocol 屬性中指定的交易通訊協定來提交訊息。 如果用戶端在交易式範圍以外提交訊息,這個接收位置會將例外狀況傳回至用戶端,而不會擱置任何訊息。

此選項只適用於單向接收位置。 如果用戶端在要求-回應接收位置的交易式內容中提交訊息,則會將例外狀況傳回至用戶端,而不會擱置任何訊息。

預設值:False
TransactionProtocol 列舉

- OleTransaction
- WS-AtomicTransaction
指定要搭配此接收位置使用的交易通訊協定。

預設值: OleTransaction
LeaseTimeout System.TimeSpan 指定作用中之集區連線的最大存留期間。 在指定的時間過去後,目前的要求獲得服務之後,連線隨即會關閉。

WCF-NetTcp 配接器會利用 NetTcpBinding 類別與端點通訊。 在負載平衡案例中使用 NetTcpBinding 時,請考慮減少預設租用逾時。如需使用 NetTcpBinding時負載平衡的詳細資訊,請參閱中的適當主題。

預設值:00:05:00
MaxConcurrentCalls 整數 指定對單一服務執行個體的並行呼叫數目。 超出上限的呼叫將排入佇列。 此屬性的範圍介於 1 和 Int32.MaxValue 之間。

預設值:200
SecurityMode 列舉

-
- 消息
- 運輸
- TransportWithMessageCredential

如需SecurityMode屬性成員名稱的詳細資訊,請參閱UI 指引和開發人員 API 命名空間參考中的WCF-NetTcp 傳輸屬性對話方塊、接收、安全性索引標籤中的安全性模式屬性。
指定使用的安全性類型。

預設值: 傳輸
TransportClientCredentialType 列舉

-
- Windows
- 證書

如需TransportClientCredentialType屬性成員名稱的詳細資訊,請參閱WCF-NetTcp 傳輸屬性對話方塊、接收、安全性索引標籤中的 [WCF-NetTcp 傳輸屬性] 對話方塊、[接收]、[安全性] 索引標籤和開發人員 API 命名空間參考
指定在執行用戶端驗證時,所要使用的認證類型。

預設值: Windows
TransportProtectionLevel 列舉

- :無保護。
- 符號:訊息已簽署。
- EncryptAndSign:訊息已加密並簽署。
定義在 TCP 傳輸層的安全性。 簽署訊息可以降低訊息在傳輸時遭到第三者竄改的風險。 加密可在傳輸時提供資料等級的隱私權。

預設值: EncryptAndSign
MessageClientCredentialType 列舉

-
- Windows
- 使用者
- 證書

如需MessageClientCredentialType屬性成員名稱的詳細資訊,請參閱WCF-NetTcp 傳輸屬性對話方塊、接收、安全性索引標籤中的 [WCF-NetTcp 傳輸屬性] 對話方塊、[接收]、[安全性] 索引標籤和開發人員 API 命名空間參考
指定當使用以訊息為基礎的安全性來執行用戶端驗證時,所要使用的認證類型。

預設值: Windows
AlgorithmSuite 列舉

如需AlgorithmSuite屬性成員名稱的詳細資訊,請參閱UI 指引和開發人員 API 命名空間參考中的WCF-NetTcp 傳輸屬性對話方塊、接收、安全性索引標籤中的演算法套件屬性。
指定訊息加密和 Key Wrap 演算法。 這些演算法會對應到安全性原則語言 (WS-SecurityPolicy) 規格中所指定的演算法。

預設值: Basic256
ServiceCertificate 字串 針對此接收位置指定用戶端用來驗證服務之 X.509 憑證的憑證指紋。 要用於此屬性的憑證必須安裝在目前使用者位置的[我的存放區] 中。 注意: 您必須針對裝載此接收位置的接收處理常式,將服務憑證安裝到使用者帳戶的 目前使用者 位置。

預設為空字串。
UseSSO Boolean 指定是否使用「企業單一登入」(SSO) 來擷取用戶端認證,以便發出 SSO 票證。 For more information about the security configurations supporting SSO, see the section, "Enterprise Single Sign-On Supportability for the WCF-NetTcp Receive Adapter" in the WCF-NetTcp Transport Properties Dialog Box, Receive, Security tab in the UI guidance and developers API namespace reference.
InboundBodyLocation 列舉

- UseBodyElement - 使用傳入訊息的 SOAP Body 元素內容來建立 BizTalk 訊息本文元件。 如果 Body 元素有一個以上的子元素,則只有第一個元素會成為 BizTalk 訊息內文部分。
- UseEnvelope - 從傳入訊息的整個 SOAP Envelope 建立 BizTalk 訊息本文部分。
- UseBodyPath - 使用 InboundBodyPathExpression 屬性中的本文路徑運算式來建立 BizTalk 訊息本文元件。 內文路徑運算式會依照內送訊息 SOAP Body 元素的直系子元素來進行評估。 此屬性只對請求-回應連接埠有效。

如需如何使用 InboundBodyLocation 屬性的詳細資訊,請參閱 指定 WCF 配接器的訊息本文
指定傳入 WCF 訊息之 SOAP Body 元素的資料選取範圍。

預設值: UseBodyElement
InboundBodyPathExpression 字串

如需如何使用 InboundBodyPathExpression 屬性的詳細資訊,請參閱 WCF 配接器屬性架構和屬性
指定內文路徑運算式來識別用於建立 BizTalk 訊息內文部分之內送訊息的特定部分。 此本文路徑運算式會根據傳入訊息之 SOAP Body 節點的立即子項目進行評估。 如果此內文路徑運算式傳回一個以上的節點,則只會為 BizTalk 訊息內文部分選擇第一個節點。 如果 InboundBodyLocation 屬性設定為 UseBodyPath,則需要這個屬性。

預設為空字串。
InboundNodeEncoding 列舉

- Base64 - Base64 編碼。
- 十六進位 - 十六進位編碼。
- 字串 - 文字編碼 - UTF-8。
- XML - WCF 配接器會使用 InboundBodyPathExpression中主體路徑運算式所選取之節點的外部 XML,建立 BizTalk 訊息本文。
指定 WCF-NetTcp 接收配接器用來解碼 由 InboundBodyPathExpression中所指定主體路徑運算式所識別的節點編碼類型。 如果 InboundBodyLocation 屬性設定為 UseBodyPath,則需要這個屬性。

預設值: XML
OutboundBodyLocation 列舉

- UseBodyElement - 使用 BizTalk 訊息本文部分,為傳出回應訊息建立 SOAP Body 元素的內容。
- UseTemplate - 使用 OutboundXMLTemplate 屬性中提供的範本,為傳出回應訊息建立 SOAP Body 元素的內容。

如需如何使用 OutboundBodyLocation 屬性的詳細資訊,請參閱 指定 WCF 配接器的訊息本文
指定傳出 WCF 訊息之 SOAP Body 元素的資料選取範圍。 此屬性只適用於要求-回應接收位置。

預設值: UseBodyElement
OutboundXMLTemplate 字串

如需如何使用 OutboundXMLTemplate 屬性的詳細資訊,請參閱 指定 WCF 配接器的訊息本文
為傳出回應訊息之 SOAP Body 元素的內容指定 XML 格式範本。 如果 OutboundBodyLocation 屬性設定為 UseTemplate,則需要這個屬性。 此屬性只適用於要求-回應接收位置。

預設為空字串。
SuspendMessageOnFailure Boolean 指定是否擱置因接收管線失敗或路由失敗而造成輸入處理失敗的要求訊息。

預設值: True
IncludeExceptionDetailInFaults Boolean 指定基於偵錯目的傳回用戶端的 SOAP 錯誤詳細資料中,是否包括 Managed 例外狀況資訊。

預設值: False

使用 BizTalk 管理主控台設定 WCF-NetTcp 接收位置

您可以在 BizTalk 管理主控台中設定 WCF-NetTcp 接收位置配接器變數。 若接收位置並未設定屬性,系統就會使用 [BizTalk 管理主控台] 中的預設接收處理常式值。

注意

完成下列程序之前,您必須已經新增接收埠。 如需詳細資訊,請參閱 如何建立接收埠

設定 WCF-NetTcp 接收位置的變數

  1. 在 BizTalk Server 管理主控台中,依序展開 [BizTalk Server 2009 管理][BizTalk 群組][應用程式],然後展開您要在其中建立接收位置的應用程式。

  2. 在 [BizTalk 管理主控台] 的左窗格中,按一下 [接收埠] 節點。 然後在右窗格中,使用滑鼠右鍵按一下與現有接收位置關聯的接收埠,或是您要與新接收位置關聯的接收埠,然後按一下 [屬性]

  3. 在 [ 接收埠屬性 ] 對話方塊的左窗格中,選取 [ 接收位置],然後在右窗格中按兩下現有的接收位置,或按一下 [ 新增] 來建立新的接收位置。

  4. 在 [接收位置屬性]對話方塊的 [類型] 旁的 [傳輸] 區段中,從下拉式清單中選取[WCF-NetTcp],然後按一下 [設定]。

  5. [WCF-NetTcp 傳輸屬性] 對話方塊的 [ 一般 ] 索引標籤上,設定 WCF-NetTcp 接收位置的端點位址和服務識別。 如需WCF-NetTcp 傳輸屬性對話方塊中 [一般] 索引標籤的詳細資訊,請參閱UI 指引和開發人員 API 命名空間參考中的WCF-NetTcp 傳輸屬性對話方塊、接收、一般索引標籤。

  6. [WCF-NetTcp 傳輸屬性 ] 對話方塊的 [ 系結 ] 索引標籤上,設定逾時和交易屬性。 如需WCF-NetTcp 傳輸屬性對話方塊中 [結] 索引標籤的詳細資訊,請參閱UI 指引和開發人員 API 命名空間參考中的WCF-NetTcp 傳輸屬性對話方塊、接收、系結索引標籤。

  7. [WCF-NetTcp 傳輸屬性 ] 對話方塊的 [ 安全性 ] 索引標籤上,定義 WCF-NetTcp 接收位置的安全性功能。 如需WCF-NetTcp 傳輸屬性對話方塊中 [安全性] 索引標籤的詳細資訊,請參閱UI 指引和開發人員 API 命名空間參考中的WCF-NetTcp 傳輸屬性對話方塊、接收、安全性索引標籤。

  8. [WCF-NetTcp 傳輸屬性 ] 對話方塊的 [ 訊息 ] 索引標籤上,指定 SOAP Body 元素的資料選取範圍。 如需WCF-NetTcp 傳輸屬性對話方塊中 [訊息] 索引標籤的詳細資訊,請參閱UI 指引和開發人員 API 命名空間參考中的WCF-NetTcp 傳輸屬性對話方塊、接收、訊息索引標籤。

以程式設計方式設定 WCF-NetTcp 接收位置

您可以使用下列格式來設定屬性:

<CustomProps>
  <InboundBodyPathExpression vt="8" />
  <InboundBodyLocation vt="8">UseBodyElement</InboundBodyLocation>
  <UseSSO vt="11">0</UseSSO>
  <MessageClientCredentialType vt="8">Windows</MessageClientCredentialType>
  <SendTimeout vt="8">00:01:00</SendTimeout>
  <OutboundXmlTemplate vt="8"><bts-msg-body xmlns="http://www.microsoft.com/schemas/bts2007" encoding="xml"/></OutboundXmlTemplate>
  <OpenTimeout vt="8">00:01:00</OpenTimeout>
  <AlgorithmSuite vt="8">Basic256</AlgorithmSuite>
  <SecurityMode vt="8">Message</SecurityMode>
  <TransportClientCredentialType vt="8">Windows</TransportClientCredentialType>
  <MaxReceivedMessageSize vt="3">2097152</MaxReceivedMessageSize>
  <CloseTimeout vt="8">00:01:00</CloseTimeout>
  <SuspendMessageOnFailure vt="11">0</SuspendMessageOnFailure>
  <EnableTransaction vt="11">0</EnableTransaction>
  <InboundNodeEncoding vt="8">Xml</InboundNodeEncoding>
  <IncludeExceptionDetailInFaults vt="11">0</IncludeExceptionDetailInFaults>
  <MaxConcurrentCalls vt="3">16</MaxConcurrentCalls>
  <ServiceCertificate vt="8" />
  <OutboundBodyLocation vt="8">UseBodyElement</OutboundBodyLocation>
</CustomProps>

下列程式碼片段會說明如何建立 WCF-NetTcp 接收位置:

// Use BizTalk Explorer object model to create new WCF-NetTcp receive location
string server = System.Environment.MachineName;
string database = "BizTalkMgmtDb";
string connectionString = string.Format("Server={0};Database={1};Integrated Security=true", server, database);
string transportConfigData = @"<CustomProps>
  <InboundBodyLocation vt=""8"">UseBodyElement</InboundBodyLocation>
  <UseSSO vt=""11"">0</UseSSO>
  <Identity vt=""8"">
    <identity>
    <userPrincipalName value=""username@contoso.com"" />
    </identity>
  </Identity>
</CustomProps>";
//requires project reference to \Program Files\Microsoft BizTalk Server 2009\Developer Tools\Microsoft.BizTalk.ExplorerOM.dll
BtsCatalogExplorer explorer = new Microsoft.BizTalk.ExplorerOM.BtsCatalogExplorer();
explorer.ConnectionString = connectionString;
// Add a new BizTalk application
Application application = explorer.AddNewApplication();
application.Name = "SampleBizTalkApplication";
// Save
explorer.SaveChanges();

// Add a new one-way receive port
IReceivePort receivePort = application.AddNewReceivePort(false);
receivePort.Name = "SampleReceivePort";
// Add a new one-way receive location
IReceiveLocation receiveLocation = receivePort.AddNewReceiveLocation();
receiveLocation.Name = "SampleReceiveLocation";
// Find a receive handler for WCF-NetTcp
int i = 0;
for(i=0; i < explorer.ReceiveHandlers.Count; ++i)
{
    if("WCF-NetTcp" == explorer.ReceiveHandlers[i].TransportType.Name)
        break;
}
receiveLocation.ReceiveHandler = explorer.ReceiveHandlers[i];
receiveLocation.Address = "net.tcp://mycomputer/samplepath";
receiveLocation.ReceivePipeline = explorer.Pipelines["Microsoft.BizTalk.DefaultPipelines.PassThruReceive"];
receiveLocation.TransportType = explorer.ProtocolTypes["WCF-NetTcp"];
receiveLocation.TransportTypeData = transportConfigData;
// Save
explorer.SaveChanges();

另請參閱

發行 WCF 接收配接器的服務中繼資料管理 BizTalk 主機和主機實例如何變更服務帳戶和密碼安裝WCF 配接器的憑證指定 WCF 配接器的訊息本文設定 WCF-NetTcp 配接器