SecurityPermissionAttribute 类

允许对使用声明安全性应用到代码中的 SecurityPermission 进行安全操作。无法继承此类。

**命名空间:**System.Security.Permissions
**程序集:**mscorlib(在 mscorlib.dll 中)

语法

声明
<SerializableAttribute> _
<ComVisibleAttribute(True)> _
<AttributeUsageAttribute(AttributeTargets.Assembly Or AttributeTargets.Class Or AttributeTargets.Struct Or AttributeTargets.Constructor Or AttributeTargets.Method, AllowMultiple:=True, Inherited:=False)> _
Public NotInheritable Class SecurityPermissionAttribute
    Inherits CodeAccessSecurityAttribute
用法
Dim instance As SecurityPermissionAttribute
[SerializableAttribute] 
[ComVisibleAttribute(true)] 
[AttributeUsageAttribute(AttributeTargets.Assembly|AttributeTargets.Class|AttributeTargets.Struct|AttributeTargets.Constructor|AttributeTargets.Method, AllowMultiple=true, Inherited=false)] 
public sealed class SecurityPermissionAttribute : CodeAccessSecurityAttribute
[SerializableAttribute] 
[ComVisibleAttribute(true)] 
[AttributeUsageAttribute(AttributeTargets::Assembly|AttributeTargets::Class|AttributeTargets::Struct|AttributeTargets::Constructor|AttributeTargets::Method, AllowMultiple=true, Inherited=false)] 
public ref class SecurityPermissionAttribute sealed : public CodeAccessSecurityAttribute
/** @attribute SerializableAttribute() */ 
/** @attribute ComVisibleAttribute(true) */ 
/** @attribute AttributeUsageAttribute(AttributeTargets.Assembly|AttributeTargets.Class|AttributeTargets.Struct|AttributeTargets.Constructor|AttributeTargets.Method, AllowMultiple=true, Inherited=false) */ 
public final class SecurityPermissionAttribute extends CodeAccessSecurityAttribute
SerializableAttribute 
ComVisibleAttribute(true) 
AttributeUsageAttribute(AttributeTargets.Assembly|AttributeTargets.Class|AttributeTargets.Struct|AttributeTargets.Constructor|AttributeTargets.Method, AllowMultiple=true, Inherited=false) 
public final class SecurityPermissionAttribute extends CodeAccessSecurityAttribute

备注

允许的声明范围取决于使用的 SecurityAction

安全属性所声明的安全信息存储在属性目标的元数据中,系统在运行时会访问这些信息。安全属性仅用于声明性安全。对于强制性安全,应使用相应的权限类。

示例

下面的声明属性示例显示为断言的能力请求 SecurityPermission 的正确方法,并声明您必须至少拥有此权限方可运行代码。

 <Assembly:SecurityPermissionAttribute(SecurityAction.RequestMinimum, _
 Assertion := True)>
'In Visual Basic, you must specify that you are using the assembly scope when making a request.
[assembly:SecurityPermissionAttribute(SecurityAction.RequestMinimum, Assertion=true)]
//In C#, you must specify that you are using the assembly scope when making a request.
[assembly:SecurityPermissionAttribute(SecurityAction::RequestMinimum,Assertion=true)];
//In C++, you must specify that you are using the assembly scope when making a request.
/** @assembly SecurityPermissionAttribute(SecurityAction.RequestMinimum, 
    Assertion = true)
 */
// In VJ#, you must specify that you are using the assembly scope
// when making a request.

下面的示例显示如何要求调用代码在链接时拥有 SecurityPermission。通常在托管库 (DLL) 中发出请求,以帮助保护方法或类不受潜在的有害代码的影响。

<SecurityPermissionAttribute(SecurityAction.Demand, _
 Unrestricted := True)> Public Class SampleClass
[SecurityPermissionAttribute(SecurityAction.Demand, Unrestricted=true)]
[SecurityPermissionAttribute(SecurityAction::Demand,Unrestricted=true)]
/** @attribute SecurityPermissionAttribute(SecurityAction.Demand, 
    Unrestricted = true)
 */

有关演示如何创建用于拒绝和要求安全权限的 SecurityPermissionAttribute 类的实例的完整示例,请参见 SecurityPermissionAttribute 构造函数。

继承层次结构

System.Object
   System.Attribute
     System.Security.Permissions.SecurityAttribute
       System.Security.Permissions.CodeAccessSecurityAttribute
        System.Security.Permissions.SecurityPermissionAttribute

线程安全

此类型的任何公共静态(Visual Basic 中的 Shared)成员都是线程安全的,但不保证所有实例成员都是线程安全的。

平台

Windows 98、Windows 2000 SP4、Windows Millennium Edition、Windows Server 2003、Windows XP Media Center Edition、Windows XP Professional x64 Edition、Windows XP SP2、Windows XP Starter Edition

.NET Framework 并不是对每个平台的所有版本都提供支持。有关受支持版本的列表,请参见系统要求

版本信息

.NET Framework

受以下版本支持:2.0、1.1、1.0

请参见

参考

SecurityPermissionAttribute 成员
System.Security.Permissions 命名空间
SecurityPermission 类
SecurityPermissionFlag

其他资源

利用属性扩展元数据