共用方式為


了解安全性原則

就 SQL Server 2008 R2 而言,本主題中列出的內容沒有變更。

報表伺服器所執行的任何程式碼都必須屬於特定程式碼存取安全性原則的一部分。這些安全性原則包含將辨識項對應至一組具名使用權限集合的程式碼群組。通常,程式碼群組會與為該群組中程式碼指定允許權限的具名使用權限集合產生關聯。執行階段會使用受信任主應用程式或載入程式所提供的辨識項來決定程式碼所屬的程式碼群組,以及因此授與程式碼的權限。Reporting Services 會遵守 Microsoft .NET Framework Common Language Runtime (CLR) 所定義的安全性原則架構。下列各節將描述 Reporting Services 中的各種程式碼類型以及與它們相關聯的原則規則。

報表伺服器組件

報表伺服器組件是包含屬於 Reporting Services 產品一部分之程式碼的組件。Reporting Services 是使用 Managed 程式碼組件撰寫而成。這些所有組件都是強式名稱 (亦即,經過數位簽署)。這些組件的程式碼群組都是使用 StrongNameMembershipCondition 所定義的,可根據組件強式名稱的公開金鑰資訊提供辨識項。此程式碼群組會被授與 FullTrust 權限集合。

報表伺服器延伸模組 (轉譯、資料、傳遞和安全性)

報表伺服器延伸模組是指您或其他協力廠商為了擴充 Reporting Services 功能而建立的自訂資料、傳遞、轉譯和安全性延伸模組。在與您要擴充之 Reporting Services 元件相關聯的原則組態檔中,您必須將 FullTrust 授與這些延伸模組或組件程式碼。隨附於 Reporting Services 的延伸模組會以報表伺服器公開金鑰簽署並接收 FullTrust 權限集合。

重要事項重要事項

您必須修改 Reporting Services 原則組態檔,以便允許任何協力廠商延伸模組的 FullTrust。如果您沒有針對自訂延伸模組加入具有 FullTrust 的程式碼群組,報表伺服器就無法使用它們。

如需有關 Reporting Services 中原則組態檔的詳細資訊,請參閱<使用 Reporting Services 安全性原則檔>。

在報表中使用的運算式

報表運算式是指包含在報表定義語言檔案之 Code 元素中的內嵌程式碼運算式或使用者定義方法。有一個已經在原則檔中設定的程式碼群組,它預設會將 Execution 權限集合授與這些運算式。此程式碼群組如下所示:

<CodeGroup
   class="UnionCodeGroup"
   version="1"
   PermissionSetName="Execution"
   Name="Report_Expressions_Default_Permissions"
   Description="This code group grants default permissions for code in report expressions and Code element. ">
    <IMembershipCondition
       class="StrongNameMembershipCondition"
       version="1"
       PublicKeyBlob="002400..."
    />
</CodeGroup>

Execution 權限允許程式碼執行,但不允許使用受保護的資源。在報表內發現的所有運算式都會編譯成一個組件 (稱為「運算式主機」組件),而該組件會儲存成已編譯報表的一部分。執行此報表時,報表伺服器會載入運算式主機組件並呼叫該組件以執行運算式。運算式主機組件會以用來定義所有運算式主機之程式碼群組的特定金鑰進行簽署。

報表運算式會參考報表物件模型集合 (欄位、參數等等),然後執行簡單的工作 (例如算術和字串作業)。執行這些簡單作業的程式碼只需要 Execution 權限。根據預設,Code 元素中的使用者定義方法和任何自訂組件都會被授與 Reporting Services 中的 Execution 權限。因此,對於大部分運算式而言,目前的組態不需要您修改任何安全性原則檔案。若要將其他權限授與運算式主機組件,系統管理員必須修改報表伺服器和報表設計師的原則組態檔,以及變更報表運算式程式碼群組。由於它是全域設定,所以變更運算式主機的預設權限就會影響所有報表。因此,強烈建議您將需要其他安全性的所有程式碼都放入自訂組件中。如此一來,只有這個組件會被授與您所需的權限。

安全性注意事項安全性注意事項

呼叫外部組件或受保護資源的程式碼應該併入自訂組件中,以便用於報表內。這樣做可讓您更有效地控制程式碼所要求和判斷提示的權限。您不應該呼叫 Code 元素內部的安全方法。這樣做會需要您將 FullTrust 授與報表運算式主機並將所有自訂程式碼完整存取權授與 CLR。

警告注意事項注意

請勿將 FullTrust 授與報表運算式主機的程式碼群組。如果您這樣做,就會讓所有報表運算式進行受保護的系統呼叫。

在報表中參考的自訂組件

某些報表運算式可以呼叫協力廠商程式碼組件 (在 Reporting Services 中也稱為自訂組件)。報表伺服器會預期這些組件在原則組態檔中至少具有 Execution 權限。根據預設,Reporting Services 隨附的原則檔案會將 Execution 權限授與所有組件,從「我的電腦」區域開始。您可以視需要將其他權限授與自訂組件。

在某些情況下,您可能必須執行在報表運算式中需要特定程式碼權限的作業。一般而言,這表示報表運算式需要呼叫安全的 CLR 程式庫方法 (例如,存取檔案或系統登錄的方法)。.NET Framework 文件集描述了進行此安全呼叫所需的程式碼權限。若要執行此呼叫,呼叫的程式碼必須被授與這些特定且安全的權限。如果您從報表運算式或 Code 元素進行此呼叫,運算式主機組件就必須被授與適當的權限。不過,一旦您將這些權限授與運算式主機,在任何報表之任何運算式中執行的所有程式碼現在都會被授與該特定權限。從自訂組件進行呼叫以及將特定權限授與該自訂組件是比較安全的做法。