RegistryPermissionAttribute-Klasse
Ermöglicht das Anwenden von Sicherheitsaktionen für RegistryPermission mithilfe der Deklarationssicherheit auf Code. Diese Klasse kann nicht geerbt werden.
Namespace: System.Security.Permissions
Assembly: mscorlib (in mscorlib.dll)
Syntax
'Declaration
<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 RegistryPermissionAttribute
Inherits CodeAccessSecurityAttribute
'Usage
Dim instance As RegistryPermissionAttribute
[SerializableAttribute]
[ComVisibleAttribute(true)]
[AttributeUsageAttribute(AttributeTargets.Assembly|AttributeTargets.Class|AttributeTargets.Struct|AttributeTargets.Constructor|AttributeTargets.Method, AllowMultiple=true, Inherited=false)]
public sealed class RegistryPermissionAttribute : CodeAccessSecurityAttribute
[SerializableAttribute]
[ComVisibleAttribute(true)]
[AttributeUsageAttribute(AttributeTargets::Assembly|AttributeTargets::Class|AttributeTargets::Struct|AttributeTargets::Constructor|AttributeTargets::Method, AllowMultiple=true, Inherited=false)]
public ref class RegistryPermissionAttribute 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 RegistryPermissionAttribute extends CodeAccessSecurityAttribute
SerializableAttribute
ComVisibleAttribute(true)
AttributeUsageAttribute(AttributeTargets.Assembly|AttributeTargets.Class|AttributeTargets.Struct|AttributeTargets.Constructor|AttributeTargets.Method, AllowMultiple=true, Inherited=false)
public final class RegistryPermissionAttribute extends CodeAccessSecurityAttribute
Hinweise
Der zulässige Gültigkeitsbereich der Deklaration hängt von der verwendeten SecurityAction ab.
Die von einem Sicherheitsattribut deklarierten Sicherheitsinformationen werden in den Metadaten des Attributziels gespeichert. Das System greift auf diese Sicherheitsinformationen zur Laufzeit zu. Sicherheitsattribute werden ausschließlich für deklarative Sicherheit verwendet. Verwenden Sie für imperative Sicherheit die entsprechende Berechtigungsklasse.
Beispiel
Im folgenden Beispiel eines deklarativen Attributs wird dargestellt, auf welche Weise RegistryPermission für den Zugriff auf den angegebenen Registrierungswert ordnungsgemäß angefordert wird, und die Anweisung erteilt, dass Sie zum Ausführen des Codes mindestens über diese Berechtigung verfügen müssen.
<Assembly: RegistryPermissionAttribute(SecurityAction.RequestMinimum, _
Read := "HKEY_LOCAL_MACHINE\HARDWARE\DESCRIPTION\System\CentralProcessor")>
'In Visual Basic, you must specify that you are using the assembly scope when making a request.
[assembly:RegistryPermissionAttribute(SecurityAction.RequestMinimum,
Read="HKEY_LOCAL_MACHINE\\HARDWARE\\DESCRIPTION\\System\\CentralProcessor")]
//In C#, you must specify that you are using the assembly scope when making a request.
[assembly:RegistryPermissionAttribute(SecurityAction::RequestMinimum,
Read="HKEY_LOCAL_MACHINE\\HARDWARE\\DESCRIPTION\\System\\CentralProcessor")];
//In C++, you must specify that you are using the assembly scope when making a request.
/** @assembly RegistryPermissionAttribute(SecurityAction.RequestMinimum,
Read = "HKEY_LOCAL_MACHINE\\HARDWARE\\DESCRIPTION\\System\\CentralProcessor")
*/
// In VJ#, you must specify that you are using the assembly scope when
// making a request.
Im folgenden Beispiel wird veranschaulicht, wie gefordert wird, dass der Aufrufcode zur Verknüpfungszeit über eine uneingeschränkte RegistryPermission verfügt. Anforderungen werden i. d. R. in verwalteten Bibliotheken (DLLs) vorgenommen, um Methoden und Klassen vor möglicherweise böswilligem Code zu schützen.
<RegistryPermissionAttribute(SecurityAction.Demand, _
Unrestricted := True)> Public Class SampleClass
[RegistryPermissionAttribute(SecurityAction.Demand, Unrestricted=true)]
[RegistryPermissionAttribute(SecurityAction::Demand,Unrestricted=true)]
/** @attribute RegistryPermissionAttribute(SecurityAction.Demand,
Unrestricted = true)
*/
Vererbungshierarchie
System.Object
System.Attribute
System.Security.Permissions.SecurityAttribute
System.Security.Permissions.CodeAccessSecurityAttribute
System.Security.Permissions.RegistryPermissionAttribute
Threadsicherheit
Alle öffentlichen statischen (Shared in Visual Basic) Member dieses Typs sind threadsicher. Bei Instanzmembern ist die Threadsicherheit nicht gewährleistet.
Plattformen
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 unterstützt nicht alle Versionen sämtlicher Plattformen. Eine Liste der unterstützten Versionen finden Sie unter Systemanforderungen.
Versionsinformationen
.NET Framework
Unterstützt in: 2.0, 1.1, 1.0
Siehe auch
Referenz
RegistryPermissionAttribute-Member
System.Security.Permissions-Namespace
RegistryPermission-Klasse
RegistryPermissionAccess-Enumeration