共用方式為


檢視訊息記錄

此主題描述如何檢視訊息記錄。

在服務追蹤檢視器中檢視訊息記錄

訊息將會如同由 WCF 處理的方式轉換。 因此,記錄的訊息只會反應記錄當時的訊息內容,而不是在網路上傳輸的內容。

由於訊息記錄輸出與訊息的傳輸格式沒有任何關係,因此訊息記錄會一律輸出解碼的訊息。 如果您已適當地設定訊息記錄,則任何記錄的訊息應為純文字。 例如,使用二進位訊息編碼器不會影響到記錄之訊息的格式 (純文字)。

XmlWriterTraceListener 的輸出是包含 XML 片段順序的檔案。 請注意該檔案不是有效的 XML 檔案。 建議您使用服務追蹤檢視器工具 (SvcTraceViewer.exe) 來檢視訊息記錄檔。 如需如何使用此工具的詳細資訊,請參閱使用服務追蹤檢視器來檢視相關追蹤並進行疑難排解

在服務追蹤檢視器中,訊息會列在 [訊息] 索引標籤。導致處理錯誤或與處理錯誤相關的訊息,會視錯誤的嚴重性以黃色 (警告層級) 或紅色 (錯誤層級) 反白顯示。 在訊息上按兩下會在處理要求的內容中顯示訊息追蹤。

注意

如果訊息沒有標頭,就不會記錄 <header/> 標記。

檢視用戶端、轉送與服務記錄的訊息

環境中可能會包含將訊息傳送給轉送的用戶端,之後再將訊息轉寄給服務。 當在三個位置都啟用訊息記錄,並且在服務追蹤檢視器工具 (SvcTraceViewer.exe) 中同時檢視這三個訊息記錄時,訊息記錄交換將以不正確的方式呈現。 這是因為訊息標頭中的 CorrelationIdActivityId,對每個傳送接收組來說不是唯一的。

您可以使用下列其中一種方法解決這個問題。

Message outgoingMessage = Message.CreateMessage(incomingMessage.Version, incomingMessage.Headers.Action, incomingMessage.GetReaderAtBodyContents());  
  
for (int i = 0; i < incomingMessage.Headers.Count; i++)  
{  
   if (incomingMessage.Headers[i].Name.Equals("ActivityId", StringComparison.InvariantCultureIgnoreCase) ||  
incomingMessage.Headers[i].Name.Equals("Action", StringComparison.InvariantCultureIgnoreCase))  
   {  
      continue;  
    }  
    outgoingMessage.Headers.CopyHeaderFrom(incomingMessage, i);  
}  

不正確之訊息記錄內容的例外情況

在下列情況中,記錄的訊息可能不是在網路上傳輸之八位元資料流的完整表示。

  • 針對 BasicHttpBinding,在 /addressing/none 命名空間中會記錄傳入訊息的封套標頭。

  • 空白可能不相符。

  • 針對傳入訊息,空白項目可以用不同方式表示。 例如,<tag></tag> 而不是 <tag/>

  • 當藉由預設或明確設定 enableLoggingKnownPii="true" 停用已知 PII 記錄時。

  • 啟用編碼以轉換至 UTF-8。

另請參閱