CodeAccessPermission.Demand CodeAccessPermission.Demand CodeAccessPermission.Demand CodeAccessPermission.Demand Method


コール スタック内の上位にあるすべての呼び出し元に、現在のインスタンスによって指定されているアクセス許可が与えられていない場合は、実行時に SecurityException を強制します。Forces a SecurityException at run time if all callers higher in the call stack have not been granted the permission specified by the current instance.

 virtual void Demand();
public void Demand ();
abstract member Demand : unit -> unit
override this.Demand : unit -> unit
Public Sub Demand ()



コール スタック内の上位にある呼び出し元に、現在のインスタンスによって指定されているアクセス許可がありません。A caller higher in the call stack does not have the permission specified by the current instance.

または-or- コール スタック内の上位にある呼び出し元が、現在のアクセス許可オブジェクトに対して Deny() を呼び出しました。A caller higher in the call stack has called Deny() on the current permission object.


このメソッドは、呼び出し元にリソースにアクセスするためのアクセス許可があることを確実にセキュリティで保護されたライブラリで通常使用されます。This method is typically used by secure libraries to ensure that callers have permission to access a resource. 安全なクラス ライブラリ ファイルのクラスを呼び出して、たとえば、Demandのために必要なFileIOPermission呼び出し元によって要求されたファイルの操作を実行する前にします。For example, a file class in a secure class library calls Demand for the necessary FileIOPermission before performing a file operation requested by the caller.

このメソッドを呼び出すコードのアクセス許可はチェックされません。チェックは、そのコードの直前の呼び出し元から開始し、スタックの上位します。The permissions of the code that calls this method are not examined; the check begins from the immediate caller of that code and proceeds up the stack. 通常、呼び出し履歴は、コール スタックに呼び出し履歴の上位にメソッドが下にあるメソッドを呼び出すように、成長として表されます。The call stack is typically represented as growing down, so that methods higher in the call stack call methods lower in the call stack. Demand 場合にのみ成功しないSecurityExceptionが発生します。Demand succeeds only if no SecurityException is raised.

注意 (継承者)

このメソッドをオーバーライドすることはできません。You cannot override this method.