Share via


稽核安全性事件

以 Windows Communication Foundation (WCF) 建立的應用程式可以使用稽核功能記錄安全性事件 (可能為成功、失敗或兩者並存)。 事件會寫入至 Windows 系統事件記錄檔,並且可以使用 [事件檢視器] 加以檢查。

稽核為系統管理員提供了一種方法,可偵測已發生或正在進行的攻擊。 此外,稽核可以協助開發人員偵錯安全性相關的問題。 例如,若授權的組態中出現錯誤,或是在檢查原則時不小心拒絕了某個授權使用者的存取,則開發人員可以藉由檢查事件日誌,快速地探索及隔離導致這個錯誤的原因。

如需詳細資訊 WCF 安全性的詳細資訊,請參閱 安全性概觀。如需詳細資訊進行 WCF 程式設計的詳細資訊,請參閱基本 WCF 程式設計

稽核層級和行為

安全性稽核目前有兩種層級:

  • 服務授權層級,其中呼叫者已獲得授權。

  • 訊息層級,其中 WCF 會檢查訊息的有效性,並驗證呼叫者。

您可以檢查兩種稽核層級為成功或失敗,這就是所謂的「稽核行為」(Audit Behavior)。

稽核記錄檔的位置

決定稽核層級和行為後,您 (或系統管理員) 就可以指定稽核記錄檔的位置。 您有三種選擇,包括:預設、應用程式和安全性。 指定為 [預設] 時,實際的記錄檔會根據所使用的系統,以及系統是否支援寫入至安全性記錄來進行。如需詳細資訊,請參閱本主題稍後的「作業系統」一節所述。

若要寫入安全性記錄檔,您必須具備 SeAuditPrivilege。 根據預設,只有本機系統帳戶和網路服務帳戶具有此權限。 若要管理安全性記錄函式 readdelete,您必須具備 SeSecurityPrivilege。 根據預設,只有系統管理員具有此權限。

相反地,通過驗證的使用者可以讀取及寫入應用程式記錄檔。根據預設,Windows XP 會將稽核事件寫入應用程式記錄檔。 記錄檔也可以包含個人資訊,所有通過驗證的使用者都可以檢視這些資訊。

隱藏稽核失敗

稽核期間可以使用的另一個選項為是否要隱藏任何稽核失敗。 根據預設,稽核失敗不會影響到應用程式。 不過,如果需要的話,您可以將選項設定為 false,如此便會擲回例外狀況。

程式設計稽核

您可以使用程式設計的方式或透過組態的方式指定稽核行為。

稽核類別

下表描述用來程式設計稽核行為的類別和屬性。

類別 描述

ServiceSecurityAuditBehavior

將稽核的設定選項啟用為服務行為。

AuditLogLocation

用於指定寫入哪個記錄檔的列舉。 可能的值為 [預設]、[應用程式] 和 [安全性]。 當您選取 [預設] 時,作業系統會判斷實際的記錄檔位置。 如需詳細資訊,請參閱本主題稍後「應用程式或安全性事件記錄檔選擇」一節的說明。

MessageAuthenticationAuditLevel

指定要在訊息層級上稽核哪種訊息驗證事件的類型。 這些選擇有 NoneFailureSuccessSuccessOrFailure

ServiceAuthorizationAuditLevel

指定要在服務層級上稽核哪種服務授權事件的類型。 這些選擇有 NoneFailureSuccessSuccessOrFailure

SuppressAuditFailure

指定當稽核失敗時,用戶端要求會產生什麼變化。 例如,當服務嘗試寫入安全性記錄檔,但不具有 SeAuditPrivilege 時。 true 的預設值表示忽略該失敗,並且正常處理用戶端要求。

如需將應用程式設定為記錄稽核事件的範例,請參閱 HOW TO:稽核 Windows Communication Foundation 安全性事件

組態

您也可以使用組態來指定稽核行為,方法是在 Behaviors element下方加入 serviceSecurityAudit element。 您必須在 Behavior element下方加入項目,如下列程式碼所示。

<configuration>
  <system.serviceModel>
    <behaviors>
      <behavior>
        <!— auditLogLocation="Application" or "Security" -—>
        <serviceSecurityAudit
                  auditLogLocation="Application"
                  suppressAuditFailure="true"
                  serviceAuthorizationAuditLevel="Failure"
                  messageAuthenticationAuditLevel="SuccessOrFailure" /> 
      </behavior>
    </behaviors>
  </system.serviceModel>
</configuration>

如果已啟用稽核,但未指定 auditLogLocation,則支援寫入至安全性記錄檔的平台會使用的預設記錄名稱為「安全性」記錄檔,否則便是「應用程式」記錄檔。 只有 Windows Server 2003 和 Windows Vista 作業系統支援寫入至安全性記錄檔。如需詳細資訊,請參閱本主題稍後「作業系統」一節的說明。

安全性考量

如果惡意使用者得知已啟用稽核,攻擊者就可以傳送無效的訊息,而造成寫入稽核項目。 如果是因為這個方法而填滿稽核記錄檔,稽核系統就會失敗。 若要避免這個狀況,請將 SuppressAuditFailure 屬性設定為 true,並使用 [事件檢視器] 的屬性來控制稽核行為。如需詳細資訊,請參閱在 Windows XP 內使用 [事件檢視器] 來檢視和管理事件記錄檔的「Microsoft 技術支援」相關文章:如何檢視並管理 Windows XP 事件檢視器中的事件記錄檔

在 Windows XP 上,任何通過驗證的使用者都可以檢視寫入 [應用程式記錄檔] 的稽核事件。

在應用程式和安全性事件記錄檔之間選擇

下表提供可協助您選擇要記錄至應用程式或安全性事件記錄檔的詳細資訊。

作業系統

系統 應用程式記錄檔 安全性記錄檔

Windows XP SP2 (含) 以後版本

支援項目

不支援

Windows Server 2003 SP1 和 Windows Vista

支援項目

執行緒內容必須擁有 SeAuditPrivilege

其他因素

除了作業系統之外,下表描述其他控制記錄啟用的設定。

因素 應用程式記錄檔 安全性記錄檔

稽核原則管理

不適用。

安全性記錄檔也可以藉由本機安全性授權 (LSA) 原則與組態來加以控制。 您也必須啟用 [稽核物件存取] 類別。

預設的使用者經驗

所有通過驗證的使用者都可以寫入應用程式記錄檔,因此不需要為應用程式處理序額外執行設定權限的步驟。

應用程式處理序 (內容) 必須具有 SeAuditPrivilege

另請參閱

工作

HOW TO:稽核 Windows Communication Foundation 安全性事件

參考

ServiceSecurityAuditBehavior
AuditLogLocation

概念

安全性概觀

其他資源

基本 WCF 程式設計
serviceSecurityAudit element
Behaviors element
Windows Server AppFabric 的資訊安全模型