다음을 통해 공유


FileIOPermissionAttribute 클래스

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

네임스페이스: 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 FileIOPermissionAttribute
    Inherits CodeAccessSecurityAttribute
‘사용 방법
Dim instance As FileIOPermissionAttribute
[SerializableAttribute] 
[ComVisibleAttribute(true)] 
[AttributeUsageAttribute(AttributeTargets.Assembly|AttributeTargets.Class|AttributeTargets.Struct|AttributeTargets.Constructor|AttributeTargets.Method, AllowMultiple=true, Inherited=false)] 
public sealed class FileIOPermissionAttribute : CodeAccessSecurityAttribute
[SerializableAttribute] 
[ComVisibleAttribute(true)] 
[AttributeUsageAttribute(AttributeTargets::Assembly|AttributeTargets::Class|AttributeTargets::Struct|AttributeTargets::Constructor|AttributeTargets::Method, AllowMultiple=true, Inherited=false)] 
public ref class FileIOPermissionAttribute 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 FileIOPermissionAttribute extends CodeAccessSecurityAttribute
SerializableAttribute 
ComVisibleAttribute(true) 
AttributeUsageAttribute(AttributeTargets.Assembly|AttributeTargets.Class|AttributeTargets.Struct|AttributeTargets.Constructor|AttributeTargets.Method, AllowMultiple=true, Inherited=false) 
public final class FileIOPermissionAttribute extends CodeAccessSecurityAttribute

설명

파일과 디렉터리는 절대 경로를 사용하여 지정합니다. 파일에 액세스하는 경우 파일을 만들거나 열 때 보안 검사가 수행됩니다. 파일을 닫고 다시 열어야 보안 검사가 다시 수행됩니다. 파일에 처음 액세스할 때 사용 권한을 검사하면 파일을 한 번만 열어 읽기/쓰기를 여러 번 수행할 수 있으므로 응용 프로그램 성능에 대한 보안 검사의 영향이 최소화됩니다.

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

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

경고

Unrestricted FileIOPermission에서는 파일 시스템 안의 모든 경로에 대한 권한을 부여합니다. 여기에는 지정된 단일 파일에 액세스하는 데 사용되는 다중 경로 이름도 포함됩니다. 파일에 대한 액세스를 Deny하려면 해당 파일에 대해 가능한 모든 경로를 Deny해야 합니다. 예를 들어 \\server\share가 네트워크 드라이브 X에 매핑된 경우 \\server\share\file에 대한 액세스를 Deny하려면 \\server\share\file, X:\file 및 해당 파일에 액세스하기 위해 사용할 수 있는 다른 모든 경로를 Deny해야 합니다.

예제

선언적 특성에 대한 다음 예제에서는 지정된 파일에 대한 모든 액세스 권한을 갖도록 FileIOPermission을 요청하는 올바른 방법과 코드를 실행하려면 최소한 이 사용 권한이 있어야 한다는 것을 보여 줍니다.

 <Assembly: FileIOPermissionAttribute(SecurityAction.RequestMinimum, _
 All := "C:\example\sample.txt")>
'In Visual Basic, you must specify that you are using the assembly scope when making a request.
[assembly:FileIOPermissionAttribute(SecurityAction.RequestMinimum, All="C:\\example\\sample.txt")]
//In C#, you must specify that you are using the assembly scope when making a request.
[assembly:FileIOPermissionAttribute(SecurityAction::RequestMinimum,All="C:\\example\\sample.txt")];
//In C++, you must specify that you are using the assembly scope when making a request.
/** @assembly FileIOPermissionAttribute(SecurityAction.RequestMinimum,
    All = "C:\\example\\sample.txt")
 */
// In VJ#, you must specify that you are using the assembly scope 
// when making a request.

다음 예제에서는 호출 코드가 링크 시간에 무제한 FileIOPermission을 갖도록 요청하는 방법을 보여 줍니다. 일반적으로 요청은 악성 코드로부터 메서드나 클래스를 보호할 수 있도록 관리되는 라이브러리(DLL)에 만들어집니다.

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

상속 계층 구조

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

스레드로부터의 안전성

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

참고 항목

참조

FileIOPermissionAttribute 멤버
System.Security.Permissions 네임스페이스
FileIOPermission 클래스
FileIOPermissionAccess 열거형

기타 리소스

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