다음을 통해 공유


StrongNameIdentityPermissionAttribute 클래스

선언적 보안을 사용하여 StrongNameIdentityPermission에 대한 보안 동작을 코드에 적용할 수 있습니다. 이 클래스는 상속될 수 없습니다.

네임스페이스: System.Security.Permissions
어셈블리: mscorlib(mscorlib.dll)

구문

‘선언
<SerializableAttribute> _
<AttributeUsageAttribute(AttributeTargets.Assembly Or AttributeTargets.Class Or AttributeTargets.Struct Or AttributeTargets.Constructor Or AttributeTargets.Method, AllowMultiple:=True, Inherited:=False)> _
<ComVisibleAttribute(True)> _
Public NotInheritable Class StrongNameIdentityPermissionAttribute
    Inherits CodeAccessSecurityAttribute
‘사용 방법
Dim instance As StrongNameIdentityPermissionAttribute
[SerializableAttribute] 
[AttributeUsageAttribute(AttributeTargets.Assembly|AttributeTargets.Class|AttributeTargets.Struct|AttributeTargets.Constructor|AttributeTargets.Method, AllowMultiple=true, Inherited=false)] 
[ComVisibleAttribute(true)] 
public sealed class StrongNameIdentityPermissionAttribute : CodeAccessSecurityAttribute
[SerializableAttribute] 
[AttributeUsageAttribute(AttributeTargets::Assembly|AttributeTargets::Class|AttributeTargets::Struct|AttributeTargets::Constructor|AttributeTargets::Method, AllowMultiple=true, Inherited=false)] 
[ComVisibleAttribute(true)] 
public ref class StrongNameIdentityPermissionAttribute sealed : public CodeAccessSecurityAttribute
/** @attribute SerializableAttribute() */ 
/** @attribute AttributeUsageAttribute(AttributeTargets.Assembly|AttributeTargets.Class|AttributeTargets.Struct|AttributeTargets.Constructor|AttributeTargets.Method, AllowMultiple=true, Inherited=false) */ 
/** @attribute ComVisibleAttribute(true) */ 
public final class StrongNameIdentityPermissionAttribute extends CodeAccessSecurityAttribute
SerializableAttribute 
AttributeUsageAttribute(AttributeTargets.Assembly|AttributeTargets.Class|AttributeTargets.Struct|AttributeTargets.Constructor|AttributeTargets.Method, AllowMultiple=true, Inherited=false) 
ComVisibleAttribute(true) 
public final class StrongNameIdentityPermissionAttribute extends CodeAccessSecurityAttribute

설명

허용되는 선언 범위는 사용되는 SecurityAction에 따라 다릅니다.

이 특성의 키 문자열은 secutil.exe를 실행하여 가져올 수 있습니다. 자세한 내용은 Secutil 도구(Secutil.exe)를 참조하십시오.

보안 특성에 의해 선언된 보안 정보는 특성 대상의 메타데이터에 저장되며, 런타임에 시스템에서 액세스할 수 있습니다. 보안 특성은 선언적 보안에만 사용됩니다. 명령적 보안의 경우 해당하는 사용 권한 클래스를 사용합니다.

StrongNameIdentityPermissionAttribute 특성은 어셈블리 수준에서 공용 멤버에 액세스하기 위한 강력한 이름 요구 사항을 정의하는 데 사용할 수 있습니다. .NET Framework 버전 2.0에서는 InternalsVisibleToAttribute 특성을 사용하여 해당 어셈블리에 있는 공용이 아닌 모든 형식을 다른 어셈블리에서 볼 수 있게 지정할 수도 있습니다. 자세한 내용은 Friend 어셈블리(C# 프로그래밍 가이드)를 참조하십시오.

예제

선언적 특성에 대한 다음 예제에서는 StrongNameIdentityPermission을 요청하는 올바른 방법과 코드를 실행하려면 최소한 이 사용 권한이 있어야 한다는 것을 보여 줍니다. 지정된 공개 키의 상대 개인 키를 사용하는 강력한 이름으로 서명된 경우에만 코드가 실행됩니다. NameVersion이 지정되지 않았으므로 이 특성은 모든 이름 및 버전과 일치합니다.

<Assembly: StrongNameIdentityPermissionAttribute( SecurityAction.RequestMinimum, _
 PublicKey := "00240000048000009400000006020000002400005253413100040000010" & _
 "00100538a4a19382e9429cf516dcf1399facdccca092a06442efaf9ecaca33457be26ee0" & _
 "073c6bde51fe0873666a62459581669b510ae1e84bef6bcb1aff7957237279d8b7e0e25b" & _
 "71ad39df36845b7db60382c8eb73f289823578d33c09e48d0d2f90ed4541e1438008142e" & _
 "f714bfe604c41a4957a4f6e6ab36b9715ec57625904c6")>
'In Visual Basic, you must specify that you are using the assembly scope when making a request.
[assembly:StrongNameIdentityPermissionAttribute(SecurityAction.RequestMinimum, 
 PublicKey="00240000048000009400000006020000002400005253413100040000010001005" +
 "38a4a19382e9429cf516dcf1399facdccca092a06442efaf9ecaca33457be26ee0073c6bde5" +
 "1fe0873666a62459581669b510ae1e84bef6bcb1aff7957237279d8b7e0e25b71ad39df3684" +
 "5b7db60382c8eb73f289823578d33c09e48d0d2f90ed4541e1438008142ef714bfe604c41a4" +
 "957a4f6e6ab36b9715ec57625904c6")]
 //In C#, you must specify that you are using the assembly scope when making a request.
[assembly:StrongNameIdentityPermissionAttribute(SecurityAction::RequestMinimum,
PublicKey="00240000048000009400000006020000002400005253413100040000010001005"
"38a4a19382e9429cf516dcf1399facdccca092a06442efaf9ecaca33457be26ee0073c6bde5"
"activatede0873666a62459581669b510ae1e84bef6bcb1aff7957237279d8b7e0e25b71ad39df3684"
"5b7db60382c8eb73f289823578d33c09e48d0d2f90ed4541e1438008142ef714bfe604c41a4"
"957a4f6e6ab36b9715ec57625904c6")];
//In C++, you must specify that you are using the assembly scope when making a request.
/** @assembly StrongNameIdentityPermissionAttribute(SecurityAction.
    RequestMinimum, PublicKey =
    "00240000048000009400000006020000002400005253413100040000010001005" 
    + "38a4a19382e9429cf516dcf1399facdccca092a06442efaf9ecaca33457be26ee0073c6bde5" 
    + "1fe0873666a62459581669b510ae1e84bef6bcb1aff7957237279d8b7e0e25b71ad39df3684" 
    + "5b7db60382c8eb73f289823578d33c09e48d0d2f90ed4541e1438008142ef714bfe604c41a4" 
    + "957a4f6e6ab36b9715ec57625904c6")
 */
// In VJ#, you must specify that you are using the assembly scope when making 
// a request.

다음 예제에서는 호출 코드가 StrongNameIdentityPermission을 갖도록 요청하는 방법을 보여 줍니다. 지정된 공개 키의 상대 개인 키를 사용하는 강력한 이름으로 서명된 경우에만 코드가 실행됩니다.

<StrongNameIdentityPermissionAttribute(SecurityAction.Demand, _
 PublicKey := "00240000048000009400000006020000002400005253413100040000010" & _
 "00100538a4a19382e9429cf516dcf1399facdccca092a06442efaf9ecaca33457be26ee0" & _
 "073c6bde51fe0873666a62459581669b510ae1e84bef6bcb1aff7957237279d8b7e0e25b" & _
 "71ad39df36845b7db60382c8eb73f289823578d33c09e48d0d2f90ed4541e1438008142e" & _
 "f714bfe604c41a4957a4f6e6ab36b9715ec57625904c6")> Public Class SampleClass
[StrongNameIdentityPermissionAttribute(SecurityAction.Demand, 
 PublicKey="00240000048000009400000006020000002400005253413100040000010001005" +
 "38a4a19382e9429cf516dcf1399facdccca092a06442efaf9ecaca33457be26ee0073c6bde5" +
 "1fe0873666a62459581669b510ae1e84bef6bcb1aff7957237279d8b7e0e25b71ad39df3684" +
 "5b7db60382c8eb73f289823578d33c09e48d0d2f90ed4541e1438008142ef714bfe604c41a4" +
 "957a4f6e6ab36b9715ec57625904c6")]
[StrongNameIdentityPermissionAttribute(SecurityAction::Demand,
PublicKey="00240000048000009400000006020000002400005253413100040000010001005"
"38a4a19382e9429cf516dcf1399facdccca092a06442efaf9ecaca33457be26ee0073c6bde5"
"activatede0873666a62459581669b510ae1e84bef6bcb1aff7957237279d8b7e0e25b71ad39df3684"
"5b7db60382c8eb73f289823578d33c09e48d0d2f90ed4541e1438008142ef714bfe604c41a4"
"957a4f6e6ab36b9715ec57625904c6")]
/** @attribute StrongNameIdentityPermissionAttribute(SecurityAction.Demand,
    PublicKey = "00240000048000009400000006020000002400005253413100040000010001005"
    + "38a4a19382e9429cf516dcf1399facdccca092a06442efaf9ecaca33457be26ee0073c6bde5" 
    + "1fe0873666a62459581669b510ae1e84bef6bcb1aff7957237279d8b7e0e25b71ad39df3684"
    + "5b7db60382c8eb73f289823578d33c09e48d0d2f90ed4541e1438008142ef714bfe604c41a4" 
    + "957a4f6e6ab36b9715ec57625904c6")
 */

상속 계층 구조

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

스레드로부터의 안전성

이 형식의 모든 public static(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에서 지원

참고 항목

참조

StrongNameIdentityPermissionAttribute 멤버
System.Security.Permissions 네임스페이스
StrongNameIdentityPermission 클래스
StrongNamePublicKeyBlob
StrongName
StrongNameMembershipCondition

기타 리소스

특성을 사용하여 메타데이터 확장