MethodBase.IsSecurityCritical プロパティ

定義

現在のメソッドまたはコンストラクターが、現在の信頼レベルでセキュリティ クリティカルまたはセキュリティ セーフ クリティカルであり、重要な操作を実行できるかどうかを示す値を取得します。

public:
 virtual property bool IsSecurityCritical { bool get(); };
public virtual bool IsSecurityCritical { get; }
member this.IsSecurityCritical : bool
Public Overridable ReadOnly Property IsSecurityCritical As Boolean

プロパティ値

Boolean

現在のメソッドまたはコンストラクターが、現在の信頼レベルでセキュリティ クリティカルまたはセキュリティ セーフ クリティカルである場合は true。透過的である場合は false

注釈

プロパティはIsSecurityCriticalIsSecuritySafeCriticalIsSecurityTransparent共通言語ランタイム (CLR) によって決定された、現在の信頼レベルでのメソッドまたはコンストラクターの透過性レベルを報告します。 これらのプロパティの組み合わせを次の表に示します。

セキュリティ レベル IsSecurityCritical IsSecuritySafeCritical IsSecurityTransparent
重大 true false false
重要セーフ true true false
透明 false false true

これらのプロパティの使用は、アセンブリとその型とメンバーのセキュリティ注釈を調べたり、現在の信頼レベルを確認したり、ランタイムの規則を複製したりするよりもはるかに簡単です。

重要

部分信頼アセンブリの場合、このプロパティの値はアセンブリの現在の信頼レベルによって異なります。 アセンブリが部分的に信頼されたアプリケーション ドメイン (サンドボックス アプリケーション ドメインなど) に読み込まれる場合、ランタイムはアセンブリのセキュリティ注釈を無視します。 アセンブリとそのすべての型は透明として扱われます。 ランタイムは、アセンブリが完全に信頼されたアプリケーション ドメイン (デスクトップ アプリケーションの既定のアプリケーション ドメインなど) に読み込まれる場合にのみ、部分信頼アセンブリのセキュリティ注釈に注意を払います。 これに対し、信頼されたアセンブリ (つまり、グローバル アセンブリ キャッシュにインストールされている厳密な名前のアセンブリ) は、アプリケーション ドメインの信頼レベルに関係なく常に完全信頼で読み込まれるため、現在の信頼レベルは常に完全に信頼されます。 アセンブリとアプリケーション ドメインの現在の信頼レベルは、そのプロパティを使用してAssembly.IsFullyTrustedAppDomain.IsFullyTrusted決定できます。

リフレクションと透明度の詳細については、「 リフレクションのセキュリティに関する考慮事項」を参照してください。 透明性の詳細については、「 セキュリティの変更」を参照してください。

適用対象

こちらもご覧ください