Assembly.Load 메서드

정의

어셈블리를 로드합니다.Loads an assembly.

오버로드

Load(Byte[], Byte[], SecurityContextSource)

생성된 어셈블리가 들어 있고 경우에 따라 기호도 포함하고 보안 컨텍스트의 소스도 지정하는 COFF(공용 개체 파일 형식) 기반 이미지를 사용하여 어셈블리를 로드합니다.Loads the assembly with a common object file format (COFF)-based image containing an emitted assembly, optionally including symbols and specifying the source for the security context. 이 어셈블리는 호출자의 애플리케이션 도메인에 로드됩니다.The assembly is loaded into the application domain of the caller.

Load(Byte[], Byte[], Evidence)

생성된 어셈블리가 들어 있고 경우에 따라 어셈블리에 대한 기호 및 증명 정보도 포함하는 COFF(공용 개체 파일 형식) 기반 이미지를 사용하여 어셈블리를 로드합니다.Loads the assembly with a common object file format (COFF)-based image containing an emitted assembly, optionally including symbols and evidence for the assembly. 이 어셈블리는 호출자의 애플리케이션 도메인에 로드됩니다.The assembly is loaded into the application domain of the caller.

Load(String, Evidence)

해당 표시 이름이 지정된 어셈블리를 로드한 다음 제공된 증명을 사용하여 이 어셈블리를 호출자의 도메인에 로드합니다.Loads an assembly given its display name, loading the assembly into the domain of the caller using the supplied evidence.

Load(AssemblyName, Evidence)

해당 AssemblyName이 지정된 어셈블리를 로드합니다.Loads an assembly given its AssemblyName. 어셈블리는 제공된 증명을 사용하여 호출자의 도메인에 로드됩니다.The assembly is loaded into the domain of the caller using the supplied evidence.

Load(Byte[])

내보낸 어셈블리가 포함된 COFF(Common Object File Format) 기반 이미지를 사용하여 어셈블리를 로드합니다.Loads the assembly with a common object file format (COFF)-based image containing an emitted assembly. 이 어셈블리는 호출자의 애플리케이션 도메인에 로드됩니다.The assembly is loaded into the application domain of the caller.

Load(String)

지정된 이름으로 어셈블리를 로드합니다.Loads an assembly with the specified name.

Load(AssemblyName)

해당 AssemblyName이 지정된 어셈블리를 로드합니다.Loads an assembly given its AssemblyName.

Load(Byte[], Byte[])

생성된 어셈블리가 들어 있고 경우에 따라 어셈블리에 대한 기호도 포함하는 COFF(공용 개체 파일 형식) 기반 이미지를 사용하여 어셈블리를 로드합니다.Loads the assembly with a common object file format (COFF)-based image containing an emitted assembly, optionally including symbols for the assembly. 이 어셈블리는 호출자의 애플리케이션 도메인에 로드됩니다.The assembly is loaded into the application domain of the caller.

Load(Byte[], Byte[], SecurityContextSource)

생성된 어셈블리가 들어 있고 경우에 따라 기호도 포함하고 보안 컨텍스트의 소스도 지정하는 COFF(공용 개체 파일 형식) 기반 이미지를 사용하여 어셈블리를 로드합니다.Loads the assembly with a common object file format (COFF)-based image containing an emitted assembly, optionally including symbols and specifying the source for the security context. 이 어셈블리는 호출자의 애플리케이션 도메인에 로드됩니다.The assembly is loaded into the application domain of the caller.

public:
 static System::Reflection::Assembly ^ Load(cli::array <System::Byte> ^ rawAssembly, cli::array <System::Byte> ^ rawSymbolStore, System::Security::SecurityContextSource securityContextSource);
public static System.Reflection.Assembly Load (byte[] rawAssembly, byte[] rawSymbolStore, System.Security.SecurityContextSource securityContextSource);
static member Load : byte[] * byte[] * System.Security.SecurityContextSource -> System.Reflection.Assembly

매개 변수

rawAssembly
Byte[]

내보낸 어셈블리가 포함된 COFF 기반 이미지인 바이트 배열입니다.A byte array that is a COFF-based image containing an emitted assembly.

rawSymbolStore
Byte[]

어셈블리의 기호를 나타내는 원시 바이트가 포함된 바이트 배열입니다.A byte array that contains the raw bytes representing the symbols for the assembly.

securityContextSource
SecurityContextSource

보안 컨텍스트의 소스입니다.The source of the security context.

반환

로드된 어셈블리입니다.The loaded assembly.

예외

rawAssemblynull입니다.rawAssembly is null.

rawAssembly는 유효한 어셈블리가 아닙니다.rawAssembly is not a valid assembly.

또는-or- rawAssembly가 현재 로드된 버전보다 이후 버전의 공용 언어 런타임으로 컴파일되었습니다.rawAssembly was compiled with a later version of the common language runtime than the version that is currently loaded.

securityContextSource 값이 열거형 값 중 하나가 아닙니다.The value of securityContextSource is not one of the enumeration values.

설명

어셈블리 보안 컨텍스트에 대 한 지정된 된 소스를 사용 하 여 호출자의 애플리케이션 도메인에 로드 됩니다.The assembly is loaded into the application domain of the caller using the specified source for the security context. rawSymbolStore 지정 된 경우 어셈블리에 대 한 기호를 나타내는 원시 바이트도 로드 됩니다.If rawSymbolStore was specified, the raw bytes that represent the symbols for the assembly are also loaded.

Load(Byte[], Byte[], Evidence)

경고

이 API는 현재 사용되지 않습니다.

생성된 어셈블리가 들어 있고 경우에 따라 어셈블리에 대한 기호 및 증명 정보도 포함하는 COFF(공용 개체 파일 형식) 기반 이미지를 사용하여 어셈블리를 로드합니다.Loads the assembly with a common object file format (COFF)-based image containing an emitted assembly, optionally including symbols and evidence for the assembly. 이 어셈블리는 호출자의 애플리케이션 도메인에 로드됩니다.The assembly is loaded into the application domain of the caller.

public:
 static System::Reflection::Assembly ^ Load(cli::array <System::Byte> ^ rawAssembly, cli::array <System::Byte> ^ rawSymbolStore, System::Security::Policy::Evidence ^ securityEvidence);
[System.Obsolete]
[System.Obsolete("This method is obsolete and will be removed in a future release of the .NET Framework. Please use an overload of Load which does not take an Evidence parameter. See https://go.microsoft.com/fwlink/?LinkID=155570 for more information.")]
public static System.Reflection.Assembly Load (byte[] rawAssembly, byte[] rawSymbolStore, System.Security.Policy.Evidence securityEvidence);
static member Load : byte[] * byte[] * System.Security.Policy.Evidence -> System.Reflection.Assembly
Public Shared Function Load (rawAssembly As Byte(), rawSymbolStore As Byte(), securityEvidence As Evidence) As Assembly

매개 변수

rawAssembly
Byte[]

내보낸 어셈블리가 포함된 COFF 기반 이미지인 바이트 배열입니다.A byte array that is a COFF-based image containing an emitted assembly.

rawSymbolStore
Byte[]

어셈블리의 기호를 나타내는 원시 바이트가 포함된 바이트 배열입니다.A byte array that contains the raw bytes representing the symbols for the assembly.

securityEvidence
Evidence

어셈블리 로드에 사용할 증명 정보입니다.Evidence for loading the assembly.

반환

로드된 어셈블리입니다.The loaded assembly.

특성

예외

rawAssemblynull인 경우rawAssembly is null.

rawAssembly는 유효한 어셈블리가 아닙니다.rawAssembly is not a valid assembly.

또는-or- 버전 2.0 이상의 공용 언어 런타임이 현재 로드되어 있으며 rawAssembly가 이후 버전으로 컴파일되었습니다.Version 2.0 or later of the common language runtime is currently loaded and rawAssembly was compiled with a later version.

어셈블리 또는 모듈이 서로 다른 두 증명 정보로 두 번 로드되었습니다.An assembly or module was loaded twice with two different evidences.

securityEvidencenull가 아닙니다.securityEvidence is not null. 기본적으로 레거시 CAS 정책은 .NET Framework 4.NET Framework 4에서 사용되지 않습니다. 사용되지 않도록 설정되면 securityEvidencenull이어야 합니다.By default, legacy CAS policy is not enabled in the .NET Framework 4.NET Framework 4; when it is not enabled, securityEvidence must be null.

설명

어셈블리는 제공된 증명을 사용하여 호출자의 도메인에 로드됩니다.The assembly is loaded into the domain of the caller using the supplied evidence. 어셈블리의 기호를 나타내는 원시 바이트도 로드 됩니다.The raw bytes representing the symbols for the assembly are also loaded.

어셈블리에 대한 특정 권한 부여 여부는 증명 정보를 바탕으로 합니다.Whether certain permissions are granted or not granted to an assembly is based on evidence. 어셈블리 및 보안 증명 정보 병합에 대 한 규칙은 다음과 같습니다.The rules for assembly and security evidence merging are as follows:

  • Evidence 매개 변수가 없는 Load 메서드를 사용 하는 경우 로더가 제공 하는 증명 정보를 사용 하 여 어셈블리가 로드 됩니다.When you use a Load method with no Evidence parameter, the assembly is loaded with the evidence that the loader supplies.

  • Evidence 매개 변수와 함께 Load 메서드를 사용 하는 경우 증명 정보 부분이 병합 됩니다.When you use a Load method with an Evidence parameter, pieces of evidence are merged. Load 메서드에 대 한 인수로 제공 되는 증명 정보는 로더에서 제공 하는 증명 정보 부분을 대체 합니다.Pieces of evidence supplied as an argument to the Load method supersede pieces of evidence supplied by the loader.

  • Byte[] 매개 변수와 함께 Load 메서드 오버 로드를 사용 하 여 COFF 이미지를 로드 하는 경우 증명 정보가 호출 어셈블리에서 상속 됩니다.When you use a Load method overload with a Byte[] parameter to load a COFF image, evidence is inherited from the calling assembly. 이는 .NET Framework 버전 1.1 SP1 (서비스 팩 1) 및 후속 릴리스에 적용 됩니다.This applies to the .NET Framework version 1.1 Service Pack 1 (SP1) and subsequent releases.

    참고

    .NET Framework 버전 1.0 및 s p 1이 포함 된 1.1 버전에서 Byte[] 매개 변수와 함께 Load 메서드 오버 로드를 사용 하 여 COFF 이미지를 로드 하는 경우 증명 정보가 결합 됩니다.In the .NET Framework version 1.0 and in version 1.1 without SP1, when you use a Load method overload with a Byte[] parameter to load a COFF image, evidence is combined. Zone, UrlSite는 호출 어셈블리에서 상속 되며 HashStrongName는 COFF 어셈블리에서 가져옵니다.Zone, Url and Site are inherited from the calling assembly, and Hash and StrongName are taken from the COFF assembly.

  • Byte[] 매개 변수와 함께 Load 메서드를 사용 하 고 COFF 이미지를 로드 하는 Evidence 경우 제공 된 증명 정보만 사용 됩니다.When you use a Load method with a Byte[] parameter and Evidence to load a COFF image, only the supplied evidence is used. 호출 어셈블리의 증명 정보와 COFF 이미지의 증명 정보는 무시 됩니다.Evidence of the calling assembly and evidence of the COFF image are ignored.

실행 파일 C++ 에 대 한 반사는 BadImageFormatException을 throw 할 수 있습니다.Reflecting on C++ executable files might throw a BadImageFormatException. 이는 C++ 컴파일러가 실행 파일에서 재배치 주소 또는 .reloc 섹션을 제거 하는 경우에 발생할 수 있습니다.This is most likely caused by the C++ compiler stripping the relocation addresses or the .reloc section from your executable file. C++ 실행 파일에 대 한 .reloc 주소를 유지 하려면 링크할 때 /fixed:no를 지정 합니다.To preserve the .reloc address for your C++ executable file, specify /fixed:no when you are linking.

[], Byte<f:% 2A > 메서드를 동일한 어셈블리에서 두 번 이상 호출 했지만 다른 증명 정보를 지정 하는 경우 공용 언어 런타임에서는 같음 및 무결성 때문에 FileLoadException를 throw 하지 않습니다. 다른 증명 정보 사양을 확인할 수 없습니다.If you call the [], Byte<xref:System.Reflection.Assembly.Load%2A> method more than once on the same assembly but with a different evidence specified, the common language runtime does not throw a FileLoadException because the equality and integrity of the different evidence specifications cannot be determined. 먼저 성공한 증명 정보는 사용 되는 증명 정보입니다.The evidence that first succeeds is the evidence that is used.

이 메서드 오버 로드는 항상 자체 매핑을 사용 하 여 새 Assembly 개체를 만듭니다.Note that this method overload always creates a new Assembly object with its own mapping.

보안

SecurityPermission
증명 정보를 제공할 수 있습니다.for the ability to supply evidence. 연관된 열거형: ControlEvidenceAssociated enumeration: ControlEvidence. 보안 동작: Demand합니다.Security action: Demand.

Load(String, Evidence)

경고

이 API는 현재 사용되지 않습니다.

해당 표시 이름이 지정된 어셈블리를 로드한 다음 제공된 증명을 사용하여 이 어셈블리를 호출자의 도메인에 로드합니다.Loads an assembly given its display name, loading the assembly into the domain of the caller using the supplied evidence.

public:
 static System::Reflection::Assembly ^ Load(System::String ^ assemblyString, System::Security::Policy::Evidence ^ assemblySecurity);
[System.Obsolete]
[System.Obsolete("This method is obsolete and will be removed in a future release of the .NET Framework. Please use an overload of Load which does not take an Evidence parameter. See https://go.microsoft.com/fwlink/?LinkID=155570 for more information.")]
public static System.Reflection.Assembly Load (string assemblyString, System.Security.Policy.Evidence assemblySecurity);
static member Load : string * System.Security.Policy.Evidence -> System.Reflection.Assembly
Public Shared Function Load (assemblyString As String, assemblySecurity As Evidence) As Assembly

매개 변수

assemblyString
String

어셈블리의 표시 이름입니다.The display name of the assembly.

assemblySecurity
Evidence

어셈블리 로드에 사용할 증명 정보입니다.Evidence for loading the assembly.

반환

로드된 어셈블리입니다.The loaded assembly.

특성

예외

assemblyStringnull입니다.assemblyString is null.

assemblyString가 없는 경우assemblyString is not found.

assemblyString는 유효한 어셈블리가 아닙니다.assemblyString is not a valid assembly.

또는-or- 버전 2.0 이상의 공용 언어 런타임이 현재 로드되어 있으며 assemblyString가 이후 버전으로 컴파일되었습니다.Version 2.0 or later of the common language runtime is currently loaded and assemblyString was compiled with a later version.

찾은 파일을 로드할 수 없습니다.A file that was found could not be loaded.

또는-or-

어셈블리 또는 모듈이 서로 다른 두 증명 정보로 두 번 로드되었습니다.An assembly or module was loaded twice with two different evidences.

설명

assemblyString 전체 어셈블리 이름을 지정 하 고, 단순 이름과 일치 하는 첫 번째 어셈블리의 버전, 문화권 또는 공개 키 토큰이 다른 경우 FileLoadException throw 됩니다.FileLoadException is thrown if assemblyString specifies the full assembly name, and the first assembly that matches the simple name has a different version, culture, or public key token. 로더에서 단순한 이름과 일치 하는 다른 어셈블리를 계속 검색 하지 않습니다.The loader does not continue probing for other assemblies that match the simple name.

어셈블리에 대한 특정 권한 부여 여부는 증명 정보를 바탕으로 합니다.Whether certain permissions are granted or not granted to an assembly is based on evidence. 어셈블리 및 보안 증명 정보 병합에 대 한 규칙은 다음과 같습니다.The rules for assembly and security evidence merging are as follows:

  • Evidence 매개 변수가 없는 Load 메서드를 사용 하는 경우 로더가 제공 하는 증명 정보를 사용 하 여 어셈블리가 로드 됩니다.When you use a Load method with no Evidence parameter, the assembly is loaded with the evidence that the loader supplies.

  • Evidence 매개 변수와 함께 Load 메서드를 사용 하는 경우 증명 정보 부분이 병합 됩니다.When you use a Load method with an Evidence parameter, pieces of evidence are merged. Load 메서드에 대 한 인수로 제공 되는 증명 정보는 로더에서 제공 하는 증명 정보 부분을 대체 합니다.Pieces of evidence supplied as an argument to the Load method supersede pieces of evidence supplied by the loader.

  • Byte[] 매개 변수와 함께 Load 메서드 오버 로드를 사용 하 여 COFF (공용 개체 파일 형식) 이미지를 로드 하는 경우 증명 정보가 호출 어셈블리에서 상속 됩니다.When you use a Load method overload with a Byte[] parameter to load a common object file format (COFF) image, evidence is inherited from the calling assembly. 이는 .NET Framework 버전 1.1 SP1 (서비스 팩 1) 및 후속 릴리스에 적용 됩니다.This applies to the .NET Framework version 1.1 Service Pack 1 (SP1) and subsequent releases.

    참고

    .NET Framework 버전 1.0 및 s p 1이 포함 된 1.1 버전에서 Byte[] 매개 변수와 함께 Load 메서드 오버 로드를 사용 하 여 COFF 이미지를 로드 하는 경우 증명 정보가 결합 됩니다.In the .NET Framework version 1.0 and in version 1.1 without SP1, when you use a Load method overload with a Byte[] parameter to load a COFF image, evidence is combined. Zone, UrlSite는 호출 어셈블리에서 상속 되며 HashStrongName는 COFF 어셈블리에서 가져옵니다.Zone, Url and Site are inherited from the calling assembly, and Hash and StrongName are taken from the COFF assembly.

  • Byte[] 매개 변수와 함께 Load 메서드를 사용 하 고 COFF 이미지를 로드 하는 Evidence 경우 제공 된 증명 정보만 사용 됩니다.When you use a Load method with a Byte[] parameter and Evidence to load a COFF image, only the supplied evidence is used. 호출 어셈블리의 증명 정보와 COFF 이미지의 증명 정보는 무시 됩니다.Evidence of the calling assembly and evidence of the COFF image is ignored.

실행 파일 C++ 에 대 한 반사는 BadImageFormatException을 throw 할 수 있습니다.Reflecting on C++ executable files might throw a BadImageFormatException. 이는 C++ 컴파일러가 실행 파일에서 재배치 주소 또는 .reloc 섹션을 제거 하는 경우에 발생할 수 있습니다.This is most likely caused by the C++ compiler stripping the relocation addresses or the .reloc section from your executable file. C++ 실행 파일에 대 한 .reloc 주소를 유지 하려면 링크할 때 /fixed:no를 지정 합니다.To preserve the .reloc address for your C++ executable file, specify /fixed:no when you are linking.

동일한 어셈블리에서이 메서드를 두 번 이상 호출 했지만 다른 증명 정보를 지정 하는 경우에는 다른 증명 정보 사양의 같음 및 무결성을 확인할 수 없기 때문에 공용 언어 런타임에서 FileLoadException을 throw 하지 않습니다.If you call this method more than once on the same assembly but with a different evidence specified, the common language runtime does not throw a FileLoadException because the equality and integrity of the different evidence specifications cannot be determined. 먼저 성공한 증명 정보는 사용 되는 증명 정보입니다.The evidence that first succeeds is the evidence that is used.

.NET Framework 버전 2.0에서는 프로세서 아키텍처가 어셈블리 id에 추가 되 고 어셈블리 이름 문자열의 일부로 지정할 수 있습니다.In the .NET Framework version 2.0, processor architecture is added to assembly identity, and can be specified as part of assembly name strings. 예를 들면 "ProcessorArchitecture = msil"입니다.For example, "ProcessorArchitecture=msil". 그러나 어셈블리 이름을 지정 하는 권장 방법은 AssemblyName 개체를 만들어 Load 메서드의 적절 한 오버 로드에 전달 하는 것입니다.However, the recommended way to specify an assembly name is to create an AssemblyName object and pass it to an appropriate overload of the Load method. AssemblyName.ProcessorArchitecture을 참조하세요.See AssemblyName.ProcessorArchitecture.

보안

SecurityPermission
증명 정보를 사용 하 여 어셈블리를 로드 합니다.to load an assembly with evidence. 연결 된 열거형: ControlEvidenceAssociated enumeration: ControlEvidence

추가 정보

Load(AssemblyName, Evidence)

경고

이 API는 현재 사용되지 않습니다.

해당 AssemblyName이 지정된 어셈블리를 로드합니다.Loads an assembly given its AssemblyName. 어셈블리는 제공된 증명을 사용하여 호출자의 도메인에 로드됩니다.The assembly is loaded into the domain of the caller using the supplied evidence.

public:
 static System::Reflection::Assembly ^ Load(System::Reflection::AssemblyName ^ assemblyRef, System::Security::Policy::Evidence ^ assemblySecurity);
[System.Obsolete]
[System.Obsolete("This method is obsolete and will be removed in a future release of the .NET Framework. Please use an overload of Load which does not take an Evidence parameter. See https://go.microsoft.com/fwlink/?LinkID=155570 for more information.")]
public static System.Reflection.Assembly Load (System.Reflection.AssemblyName assemblyRef, System.Security.Policy.Evidence assemblySecurity);
static member Load : System.Reflection.AssemblyName * System.Security.Policy.Evidence -> System.Reflection.Assembly
Public Shared Function Load (assemblyRef As AssemblyName, assemblySecurity As Evidence) As Assembly

매개 변수

assemblyRef
AssemblyName

로드될 어셈블리를 설명하는 개체입니다.The object that describes the assembly to be loaded.

assemblySecurity
Evidence

어셈블리 로드에 사용할 증명 정보입니다.Evidence for loading the assembly.

반환

로드된 어셈블리입니다.The loaded assembly.

특성

예외

assemblyRefnull인 경우assemblyRef is null.

assemblyRef가 없는 경우assemblyRef is not found.

assemblyRef는 유효한 어셈블리가 아닙니다.assemblyRef is not a valid assembly.

또는-or- 버전 2.0 이상의 공용 언어 런타임이 현재 로드되어 있으며 assemblyRef가 이후 버전으로 컴파일되었습니다.Version 2.0 or later of the common language runtime is currently loaded and assemblyRef was compiled with a later version.

어셈블리 또는 모듈이 서로 다른 두 증명 정보로 두 번 로드되었습니다.An assembly or module was loaded twice with two different evidences.

또는-or-

assemblyRef은 원격 어셈블리를 지정하지만 원격 어셈블리에서 코드를 실행하는 기능은 사용할 수 없습니다.assemblyRef specifies a remote assembly, but the ability to execute code in remote assemblies is disabled. <loadFromRemoteSources>를 확인하세요.See <loadFromRemoteSources>.

설명

assemblyRef 전체 어셈블리 이름을 지정 하 고, 단순 이름과 일치 하는 첫 번째 어셈블리의 버전, 문화권 또는 공개 키 토큰이 다른 경우 FileLoadException throw 됩니다.FileLoadException is thrown if assemblyRef specifies the full assembly name, and the first assembly that matches the simple name has a different version, culture, or public key token. 로더에서 단순한 이름과 일치 하는 다른 어셈블리를 계속 검색 하지 않습니다.The loader does not continue probing for other assemblies that match the simple name. .NET Framework 4부터 원격 어셈블리의 코드 실행은 기본적으로 사용 하지 않도록 설정 되어 있으므로 assemblyRef에서 원격 어셈블리를 지정 하는 경우에도 FileLoadException throw 됩니다.Starting with .NET Framework 4, because execution of code in remote assemblies is disabled by default, a FileLoadException is also thrown if assemblyRef specifies a remote assembly. 원격 위치에서 로드 된 코드를 실행할 수 있도록 <loadFromRemoteSources> 구성 요소를 사용할 수 있습니다.To enable execution of code loaded from remote locations, you can use the <loadFromRemoteSources> configuration element.

참고

CodeBase 속성 집합만 사용 하 여 AssemblyName을 사용 하지 마십시오.Do not use an AssemblyName with only the CodeBase property set. CodeBase 속성은 어셈블리 id의 요소 (예: 이름 또는 버전)를 제공 하지 않으므로 Load 메서드에서와 같이 id에의 한 로드 규칙에 따라 로드를 수행 하지 않습니다.The CodeBase property does not supply any elements of the assembly identity (such as name or version), so loading does not occur according to load-by-identity rules, as you would expect from the Load method. 대신 어셈블리는 로드 시 규칙을 사용 하 여 로드 됩니다.Instead, the assembly is loaded using load-from rules. 로드 시 컨텍스트 사용의 단점에 대 한 자세한 내용은 Assembly.LoadFrom 메서드 오버 로드 또는 어셈블리 로드에 대 한 모범 사례를 참조 하세요.For information about the disadvantages of using the load-from context, see the Assembly.LoadFrom method overload or Best Practices for Assembly Loading.

어셈블리에 대한 특정 권한 부여 여부는 증명 정보를 바탕으로 합니다.Whether certain permissions are granted or not granted to an assembly is based on evidence. 어셈블리 및 보안 증명 정보 병합에 대 한 규칙은 다음과 같습니다.The rules for assembly and security evidence merging are as follows:

  • Evidence 매개 변수가 없는 Load 메서드를 사용 하는 경우 로더가 제공 하는 증명 정보를 사용 하 여 어셈블리가 로드 됩니다.When you use a Load method with no Evidence parameter, the assembly is loaded with the evidence that the loader supplies.

  • Evidence 매개 변수와 함께 Load 메서드를 사용 하는 경우 증명 정보 부분이 병합 됩니다.When you use a Load method with an Evidence parameter, pieces of evidence are merged. Load 메서드에 대 한 인수로 제공 되는 증명 정보는 로더에서 제공 하는 증명 정보 부분을 대체 합니다.Pieces of evidence supplied as an argument to the Load method supersede pieces of evidence supplied by the loader.

  • Byte[] 매개 변수와 함께 Load 메서드 오버 로드를 사용 하 여 COFF (공용 개체 파일 형식) 이미지를 로드 하는 경우 증명 정보가 호출 어셈블리에서 상속 됩니다.When you use a Load method overload with a Byte[] parameter to load a common object file format (COFF) image, evidence is inherited from the calling assembly. 이는 .NET Framework 버전 1.1 SP1 (서비스 팩 1) 및 후속 릴리스에 적용 됩니다.This applies to the .NET Framework version 1.1 Service Pack 1 (SP1) and subsequent releases.

    참고

    .NET Framework 버전 1.0 및 s p 1이 포함 된 1.1 버전에서 Byte[] 매개 변수와 함께 Load 메서드 오버 로드를 사용 하 여 COFF 이미지를 로드 하는 경우 증명 정보가 결합 됩니다.In the .NET Framework version 1.0 and in version 1.1 without SP1, when you use a Load method overload with a Byte[] parameter to load a COFF image, evidence is combined. Zone, UrlSite는 호출 어셈블리에서 상속 되며 HashStrongName는 COFF 어셈블리에서 가져옵니다.Zone, Url and Site are inherited from the calling assembly, and Hash and StrongName are taken from the COFF assembly.

  • Byte[] 매개 변수와 함께 Load 메서드를 사용 하 고 COFF 이미지를 로드 하는 Evidence 경우 제공 된 증명 정보만 사용 됩니다.When you use a Load method with a Byte[] parameter and Evidence to load a COFF image, only the supplied evidence is used. 호출 어셈블리의 증명 정보와 COFF 이미지의 증명 정보는 무시 됩니다.Evidence of the calling assembly and evidence of the COFF image is ignored.

실행 파일 C++ 에 대 한 반사는 BadImageFormatException을 throw 할 수 있습니다.Reflecting on C++ executable files might throw a BadImageFormatException. 이는 C++ 컴파일러가 실행 파일에서 재배치 주소 또는 .reloc 섹션을 제거 하는 경우에 발생할 수 있습니다.This is most likely caused by the C++ compiler stripping the relocation addresses or the .reloc section from your executable file. C++ 실행 파일에 대 한 .reloc 주소를 유지 하려면 링크할 때 /fixed:no를 지정 합니다.To preserve the .reloc address for your C++ executable file, specify /fixed:no when you are linking.

참고

AssemblyName.Name 속성과 AssemblyName.CodeBase 속성이 모두 설정 되어 있는 경우 어셈블리를 로드 하려는 첫 번째 시도는 Assembly.FullName 속성에 의해 반환 되는 버전, 문화권 등을 비롯 한 표시 이름을 사용 합니다.If both the AssemblyName.Name property and the AssemblyName.CodeBase property are set, the first attempt to load the assembly uses the display name (including version, culture, and so on, as returned by the Assembly.FullName property). 파일을 찾을 수 없는 경우 CodeBase를 사용 하 여 어셈블리를 검색 합니다.If the file is not found, CodeBase is used to search for the assembly. CodeBase를 사용 하 여 어셈블리를 찾으면 표시 이름이 어셈블리와 일치 합니다.If the assembly is found using CodeBase, the display name is matched against the assembly. 일치가 실패 하면 FileLoadException이 throw 됩니다.If the match fails, a FileLoadException is thrown.

동일한 어셈블리에서 Load 메서드를 두 번 이상 호출 했지만 다른 증명 정보를 지정 하는 경우에는 다른 증명 정보 사양의 같음 및 무결성을 확인할 수 없기 때문에 공용 언어 런타임에서 FileLoadException를 throw 하지 않습니다.If you call the Load method more than once on the same assembly but with a different evidence specified, the common language runtime does not throw a FileLoadException because the equality and integrity of the different evidence specifications cannot be determined. 먼저 성공한 증명 정보는 사용 되는 증명 정보입니다.The evidence that first succeeds is the evidence that is used.

보안

FileIOPermission
파일이 나 디렉터리에서 읽고 경로 자체의 정보에 액세스 하기 위한입니다.for access to read from a file or directory, and for access to the information in the path itself. 연관 된 열거형: Read, PathDiscoveryAssociated enumerations: Read, PathDiscovery

WebPermission
"file://"로 시작 하지 않는 URI를 읽는 합니다.for reading a URI that does not begin with "file://".

SecurityPermission
증명 정보를 사용 하 여 어셈블리를 로드 합니다.to load an assembly with evidence. 연결 된 열거형: ControlEvidenceAssociated enumeration: ControlEvidence

추가 정보

Load(Byte[])

내보낸 어셈블리가 포함된 COFF(Common Object File Format) 기반 이미지를 사용하여 어셈블리를 로드합니다.Loads the assembly with a common object file format (COFF)-based image containing an emitted assembly. 이 어셈블리는 호출자의 애플리케이션 도메인에 로드됩니다.The assembly is loaded into the application domain of the caller.

public:
 static System::Reflection::Assembly ^ Load(cli::array <System::Byte> ^ rawAssembly);
public static System.Reflection.Assembly Load (byte[] rawAssembly);
static member Load : byte[] -> System.Reflection.Assembly
Public Shared Function Load (rawAssembly As Byte()) As Assembly

매개 변수

rawAssembly
Byte[]

내보낸 어셈블리가 포함된 COFF 기반 이미지인 바이트 배열입니다.A byte array that is a COFF-based image containing an emitted assembly.

반환

로드된 어셈블리입니다.The loaded assembly.

예외

rawAssemblynull인 경우rawAssembly is null.

rawAssembly는 유효한 어셈블리가 아닙니다.rawAssembly is not a valid assembly.

또는-or- 버전 2.0 이상의 공용 언어 런타임이 현재 로드되어 있으며 rawAssembly가 이후 버전으로 컴파일되었습니다.Version 2.0 or later of the common language runtime is currently loaded and rawAssembly was compiled with a later version.

설명

이 메서드를 사용 하 여 로드 된 어셈블리의 신뢰 수준은 호출 하는 어셈블리의 신뢰 수준과 동일 합니다.The trust level of an assembly that is loaded by using this method is the same as the trust level of the calling assembly. 애플리케이션 도메인의 신뢰 수준 사용 하 여 바이트 배열에서 어셈블리를 로드 하려면 사용 된 Load(Byte[], Byte[], SecurityContextSource) 메서드 오버 로드 합니다.To load an assembly from a byte array with the trust level of the application domain, use the Load(Byte[], Byte[], SecurityContextSource) method overload. 바이트 배열을 사용 하는 Load 메서드의 오버 로드에 증명 정보를 사용 하는 방법에 대 한 자세한 내용은 Load(Byte[], Byte[], Evidence) 메서드 오버 로드를 참조 하세요.For more information about the use of evidence with overloads of the Load method that take byte arrays, see the Load(Byte[], Byte[], Evidence) method overload.

실행 파일 C++ 에 대 한 반사는 BadImageFormatException을 throw 할 수 있습니다.Reflecting on C++ executable files might throw a BadImageFormatException. 이는 C++ 컴파일러가 실행 파일에서 재배치 주소 또는 .reloc 섹션을 제거 하는 경우에 발생할 수 있습니다.This is most likely caused by the C++ compiler stripping the relocation addresses or the .reloc section from your executable file. C++ 실행 파일에 대 한 .reloc 주소를 유지 하려면 링크할 때 /fixed:no를 지정 합니다.To preserve the .reloc address for your C++ executable file, specify /fixed:no when you are linking.

이 메서드 오버 로드는 항상 자체 매핑을 사용 하 여 새 Assembly 개체를 만듭니다.Note that this method overload always creates a new Assembly object with its own mapping.

Load(String)

지정된 이름으로 어셈블리를 로드합니다.Loads an assembly with the specified name.

public:
 static System::Reflection::Assembly ^ Load(System::String ^ assemblyString);
public static System.Reflection.Assembly Load (string assemblyString);
static member Load : string -> System.Reflection.Assembly
Public Shared Function Load (assemblyString As String) As Assembly

매개 변수

assemblyString
String

긴 형식 또는 짧은 형식의 어셈블리 이름입니다.The long or short form of the assembly name.

반환

로드된 어셈블리입니다.The loaded assembly.

예외

assemblyStringnull입니다.assemblyString is null.

assemblyString 이 빈 문자열입니다.assemblyString is a zero-length string.

assemblyString가 없는 경우assemblyString is not found.

찾은 파일을 로드할 수 없습니다.A file that was found could not be loaded.

assemblyString는 유효한 어셈블리가 아닙니다.assemblyString is not a valid assembly.

또는-or- 버전 2.0 이상의 공용 언어 런타임이 현재 로드되어 있으며 assemblyString가 이후 버전으로 컴파일되었습니다.Version 2.0 or later of the common language runtime is currently loaded and assemblyString was compiled with a later version.

예제

다음 예제에서는 정규화 된 이름이 지정 된 어셈블리를 로드 하 고 지정 된 어셈블리에 포함 된 모든 형식을 나열 합니다.The following example loads an assembly given its fully qualified name, and lists all the types contained in the specified assembly. 참조 된 정규화 된 어셈블리 이름을 가져오는 방법에 대 한 내용은 어셈블리 이름합니다.For information about how to obtain the fully qualified assembly name, see Assembly Names.

using namespace System;
using namespace System::Collections;
using namespace System::Reflection;
int main()
{
    // You must supply a valid fully qualified assembly name.            
    Assembly^ SampleAssembly = Assembly::Load
        ( "SampleAssembly, Version=1.0.2004.0, Culture=neutral, PublicKeyToken=8744b20f8da049e3" );
    array<Type^>^ Types = SampleAssembly->GetTypes();
    
    // Display all the types contained in the specified assembly.
    IEnumerator^ myEnum = Types->GetEnumerator();
    Type^ oType;
    while ( myEnum->MoveNext() )
    {
        oType = safe_cast<Type^>(myEnum->Current);
        Console::WriteLine( oType->Name );
    }
}

using System;
using System.Reflection;

class Class1
{
    public static void Main()
    {
        // You must supply a valid fully qualified assembly name.            
        Assembly SampleAssembly = Assembly.Load
            ("SampleAssembly, Version=1.0.2004.0, Culture=neutral, PublicKeyToken=8744b20f8da049e3");
        // Display all the types contained in the specified assembly.
        foreach (Type oType in SampleAssembly.GetTypes()) {
            Console.WriteLine(oType.Name);
        }
    }
}
Imports System.Reflection

Class Class1
    Public Shared Sub Main()
        ' You must supply a valid fully qualified assembly name.            
        Dim SampleAssembly As [Assembly] = _
            [Assembly].Load("SampleAssembly, Version=1.0.2004.0, Culture=neutral, PublicKeyToken=8744b20f8da049e3")
        Dim oType As Type
        ' Display all the types contained in the specified assembly.
        For Each oType In SampleAssembly.GetTypes()
            Console.WriteLine(oType.Name)
        Next oType
    End Sub	'LoadSample
End Class

설명

올바른 어셈블리를 로드 하려면 긴 형식의 어셈블리 이름을 전달 하 여 Load 메서드를 호출 하는 것이 좋습니다.To load the correct assembly, it's recommended to call the Load method by passing the long form of the assembly name. 긴 형식의 어셈블리 이름은 해당 버전, 문화권, 공개 키 토큰 및 선택적으로 프로세서 아키텍처와 함께 간단한 이름 (예: System.object 어셈블리의 경우 "System")으로 구성 됩니다.The long form of an assembly name consists of its simple name (such as "System" for the System.dll assembly) along with its version, culture, public key token, and optionally its processor architecture. 어셈블리의 FullName 속성에 해당 합니다.It corresponds to the assembly's FullName property. 다음 예제에서는 긴 이름을 사용 하 여 .NET Framework 4의 System.object 어셈블리를 로드 하는 방법을 보여 줍니다.The following example illustrates the use of a long name to load the System.dll assembly for the .NET Framework 4:

using System;
using System.Reflection;

public class Example
{
   public static void Main()
   {
      string longName = "system, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089";
      Assembly assem = Assembly.Load(longName);
      if (assem == null)
         Console.WriteLine("Unable to load assembly...");
      else
         Console.WriteLine(assem.FullName);
   }
}
// The example displays the following output:
//        system, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089
Imports System.Reflection

Module Example
   Public Sub Main()
      Dim longName As String = "system, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089"
      Dim assem As Assembly = Assembly.Load(longName)
      If assem Is Nothing Then
         Console.WriteLine("Unable to load assembly...")
      Else
         Console.WriteLine(assem.FullName)
      End If
   End Sub
End Module
' The example displays the following output:
'       system, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089

assemblyString 전체 어셈블리 이름을 지정 하 고, 단순 이름과 일치 하는 첫 번째 어셈블리의 버전, 문화권 또는 공개 키 토큰이 다른 경우 FileLoadException throw 됩니다.FileLoadException is thrown if assemblyString specifies the full assembly name, and the first assembly that matches the simple name has a different version, culture, or public key token. 로더에서 단순한 이름과 일치 하는 다른 어셈블리를 계속 검색 하지 않습니다.The loader does not continue probing for other assemblies that match the simple name.

어셈블리에 대한 특정 권한 부여 여부는 증명 정보를 바탕으로 합니다.Whether certain permissions are granted or not granted to an assembly is based on evidence. 어셈블리 및 보안 증명 정보 병합에 대 한 규칙은 다음과 같습니다.The rules for assembly and security evidence merging are as follows:

  • Evidence 매개 변수가 없는 Load 메서드를 사용 하는 경우 로더가 제공 하는 증명 정보를 사용 하 여 어셈블리가 로드 됩니다.When you use a Load method with no Evidence parameter, the assembly is loaded with the evidence that the loader supplies.

  • Evidence 매개 변수와 함께 Load 메서드를 사용 하는 경우 증명 정보 부분이 병합 됩니다.When you use a Load method with an Evidence parameter, pieces of evidence are merged. Load 메서드에 대 한 인수로 제공 되는 증명 정보는 로더에서 제공 하는 증명 정보 부분을 대체 합니다.Pieces of evidence supplied as an argument to the Load method supersede pieces of evidence supplied by the loader.

  • Byte[] 매개 변수와 함께 Load 메서드 오버 로드를 사용 하 여 COFF (공용 개체 파일 형식) 이미지를 로드 하는 경우 증명 정보가 호출 어셈블리에서 상속 됩니다.When you use a Load method overload with a Byte[] parameter to load a common object file format (COFF) image, evidence is inherited from the calling assembly. 이는 .NET Framework 버전 1.1 SP1 (서비스 팩 1) 및 후속 릴리스에 적용 됩니다.This applies to the .NET Framework version 1.1 Service Pack 1 (SP1) and subsequent releases.

    참고

    .NET Framework 버전 1.0 및 s p 1이 포함 된 1.1 버전에서 Byte[] 매개 변수와 함께 Load 메서드 오버 로드를 사용 하 여 COFF 이미지를 로드 하는 경우 증명 정보가 결합 됩니다.In the .NET Framework version 1.0 and in version 1.1 without SP1, when you use a Load method overload with a Byte[] parameter to load a COFF image, evidence is combined. Zone, UrlSite는 호출 어셈블리에서 상속 되며 HashStrongName는 COFF 어셈블리에서 가져옵니다.Zone, Url and Site are inherited from the calling assembly, and Hash and StrongName are taken from the COFF assembly.

  • Byte[] 매개 변수와 함께 Load 메서드를 사용 하 고 COFF 이미지를 로드 하는 Evidence 경우 제공 된 증명 정보만 사용 됩니다.When you use a Load method with a Byte[] parameter and Evidence to load a COFF image, only the supplied evidence is used. 호출 어셈블리의 증명 정보와 COFF 이미지의 증명 정보는 무시 됩니다.Evidence of the calling assembly and evidence of the COFF image is ignored.

실행 파일 C++ 에 대 한 반사는 BadImageFormatException을 throw 할 수 있습니다.Reflecting on C++ executable files might throw a BadImageFormatException. 이는 C++ 컴파일러가 실행 파일에서 재배치 주소 또는 .reloc 섹션을 제거 하는 경우에 발생할 수 있습니다.This is most likely caused by the C++ compiler stripping the relocation addresses or the .reloc section from your executable file. C++ 실행 파일에 대 한 .reloc 주소를 유지 하려면 링크할 때 /fixed:no를 지정 합니다.To preserve the .reloc address for your C++ executable file, specify /fixed:no when you are linking.

.NET Framework 버전 2.0에서는 프로세서 아키텍처가 어셈블리 id에 추가 되 고 어셈블리 이름 문자열의 일부로 지정할 수 있습니다.In the .NET Framework version 2.0, processor architecture is added to assembly identity, and can be specified as part of assembly name strings. 예를 들면 "ProcessorArchitecture = msil"입니다.For example, "ProcessorArchitecture=msil". 그러나 어셈블리 이름을 지정 하는 권장 방법은 AssemblyName 개체를 만들어 Load 메서드의 적절 한 오버 로드에 전달 하는 것입니다.However, the recommended way to specify an assembly name is to create an AssemblyName object and pass it to an appropriate overload of the Load method. AssemblyName.ProcessorArchitecture을 참조하세요.See AssemblyName.ProcessorArchitecture.

보안

SecurityPermission
증명 정보를 사용 하 여 어셈블리를 로드 합니다.to load an assembly with evidence. 연결 된 열거형: ControlEvidenceAssociated enumeration: ControlEvidence

추가 정보

Load(AssemblyName)

해당 AssemblyName이 지정된 어셈블리를 로드합니다.Loads an assembly given its AssemblyName.

public:
 static System::Reflection::Assembly ^ Load(System::Reflection::AssemblyName ^ assemblyRef);
public static System.Reflection.Assembly Load (System.Reflection.AssemblyName assemblyRef);
static member Load : System.Reflection.AssemblyName -> System.Reflection.Assembly
Public Shared Function Load (assemblyRef As AssemblyName) As Assembly

매개 변수

assemblyRef
AssemblyName

로드될 어셈블리를 설명하는 개체입니다.The object that describes the assembly to be loaded.

반환

로드된 어셈블리입니다.The loaded assembly.

예외

assemblyRefnull인 경우assemblyRef is null.

assemblyRef 가 없는 경우assemblyRef is not found.

Windows 스토어 앱용 .NET 또는 이식 가능한 클래스 라이브러리에서 대신 기본 클래스 예외 IOException을 catch합니다.In the .NET for Windows Store apps or the Portable Class Library, catch the base class exception, IOException, instead.

찾은 파일을 로드할 수 없습니다.A file that was found could not be loaded.

또는-or-

assemblyRef은 원격 어셈블리를 지정하지만 원격 어셈블리에서 코드를 실행하는 기능은 사용할 수 없습니다.assemblyRef specifies a remote assembly, but the ability to execute code in remote assemblies is disabled. <loadFromRemoteSources>를 확인하세요.See <loadFromRemoteSources>.

assemblyRef는 유효한 어셈블리가 아닙니다.assemblyRef is not a valid assembly. 또는-or- 버전 2.0 이상의 공용 언어 런타임이 현재 로드되어 있으며 assemblyRef가 이후 버전으로 컴파일되었습니다.Version 2.0 or later of the common language runtime is currently loaded and assemblyRef was compiled with a later version.

예제

다음 예제에서는 AssemblyName 개체를 인스턴스화하고이를 사용 하 여 sysglobal.dll 어셈블리를 로드 합니다.The following example instantiates an AssemblyName object and uses it to load the sysglobal.dll assembly. 그런 다음이 예제에서는 어셈블리의 public 형식에 대 한 전체 이름을 표시 합니다.The example then displays the full name of the assembly's public types.

using System;
using System.Reflection;

public class Example
{
   public static void Main()
   {
      String fullName = "sysglobl, Version=4.0.0.0, Culture=neutral, " +
                        "PublicKeyToken=b03f5f7f11d50a3a, processor architecture=MSIL";
      var an = new AssemblyName(fullName);
      var assem = Assembly.Load(an);
      Console.WriteLine("Public types in assembly {0}:", assem.FullName);
      foreach (var t in assem.GetTypes())
         if (t.IsPublic)
            Console.WriteLine("   {0}", t.FullName);
   }
}
// The example displays the following output:
//   Public types in assembly sysglobl, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a:
//      System.Globalization.CultureAndRegionInfoBuilder
//      System.Globalization.CultureAndRegionModifiers
Imports System.Reflection

Module Example
   Public Sub Main()
      Dim fullName As String = "sysglobl, Version=4.0.0.0, Culture=neutral, " +
                               "PublicKeyToken=b03f5f7f11d50a3a, processor architecture=MSIL"
      Dim an As New AssemblyName(fullName)
      Dim assem As Assembly = Assembly.Load(an)
      Console.WriteLine("Public types in assembly {0}:", assem.FullName)
      For Each t As Type in assem.GetTypes()
         If t.IsPublic Then Console.WriteLine("   {0}", t.FullName)
      Next
   End Sub
End Module
' The example displays the following output:
'   Public types in assembly sysglobl, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a:
'      System.Globalization.CultureAndRegionInfoBuilder
'      System.Globalization.CultureAndRegionModifiers

설명

assemblyRef 전체 어셈블리 이름을 지정 하 고 단순 이름과 일치 하는 첫 번째 어셈블리의 버전, 문화권 또는 공개 키 토큰이 다른 경우 FileLoadException throw 됩니다.FileLoadException is thrown if assemblyRef specifies the full assembly name and the first assembly that matches the simple name has a different version, culture, or public key token. 로더에서 단순한 이름과 일치 하는 다른 어셈블리를 계속 검색 하지 않습니다.The loader does not continue probing for other assemblies that match the simple name. .NET Framework 4부터 원격 어셈블리의 코드 실행은 기본적으로 사용 하지 않도록 설정 되어 있으므로 assemblyRef에서 원격 어셈블리를 지정 하는 경우에도 FileLoadException throw 됩니다.Starting with .NET Framework 4, because execution of code in remote assemblies is disabled by default, a FileLoadException is also thrown if assemblyRef specifies a remote assembly. 원격 위치에서 로드 된 코드를 실행할 수 있도록 <loadFromRemoteSources> 구성 요소를 사용할 수 있습니다.To enable execution of code loaded from remote locations, you can use the <loadFromRemoteSources> configuration element.

참고

CodeBase 속성 집합만 사용 하 여 AssemblyName을 사용 하지 마십시오.Do not use an AssemblyName with only the CodeBase property set. CodeBase 속성은 어셈블리 id의 요소 (예: 이름 또는 버전)를 제공 하지 않으므로 Load 메서드에서와 같이 id에의 한 로드 규칙에 따라 로드를 수행 하지 않습니다.The CodeBase property does not supply any elements of the assembly identity (such as name or version), so loading does not occur according to load-by-identity rules, as you would expect from the Load method. 대신 어셈블리는 로드 시 규칙을 사용 하 여 로드 됩니다.Instead, the assembly is loaded using load-from rules. 로드 시 컨텍스트 사용의 단점에 대 한 자세한 내용은 Assembly.LoadFrom 메서드 오버 로드 또는 어셈블리 로드에 대 한 모범 사례를 참조 하세요.For information about the disadvantages of using the load-from context, see the Assembly.LoadFrom method overload or Best Practices for Assembly Loading.

어셈블리에 대한 특정 권한 부여 여부는 증명 정보를 바탕으로 합니다.Whether certain permissions are granted or not granted to an assembly is based on evidence. 어셈블리 및 보안 증명 정보 병합에 대 한 규칙은 다음과 같습니다.The rules for assembly and security evidence merging are as follows:

  • Evidence 매개 변수가 없는 Load 메서드를 사용 하는 경우 로더가 제공 하는 증명 정보를 사용 하 여 어셈블리가 로드 됩니다.When you use a Load method with no Evidence parameter, the assembly is loaded with the evidence that the loader supplies.

  • Evidence 매개 변수와 함께 Load 메서드를 사용 하는 경우 증명 정보 부분이 병합 됩니다.When you use a Load method with an Evidence parameter, pieces of evidence are merged. Load 메서드에 대 한 인수로 제공 되는 증명 정보는 로더에서 제공 하는 증명 정보 부분을 대체 합니다.Pieces of evidence supplied as an argument to the Load method supersede pieces of evidence supplied by the loader.

  • Byte[] 매개 변수와 함께 Load 메서드 오버 로드를 사용 하 여 COFF (공용 개체 파일 형식) 이미지를 로드 하는 경우 증명 정보가 호출 어셈블리에서 상속 됩니다.When you use a Load method overload with a Byte[] parameter to load a common object file format (COFF) image, evidence is inherited from the calling assembly. 이는 .NET Framework 버전 1.1 SP1 (서비스 팩 1) 및 후속 릴리스에 적용 됩니다.This applies to the .NET Framework version 1.1 Service Pack 1 (SP1) and subsequent releases.

    참고

    .NET Framework 버전 1.0 및 s p 1이 포함 된 1.1 버전에서 Byte[] 매개 변수와 함께 Load 메서드 오버 로드를 사용 하 여 COFF 이미지를 로드 하는 경우 증명 정보가 결합 됩니다.In the .NET Framework version 1.0 and in version 1.1 without SP1, when you use a Load method overload with a Byte[] parameter to load a COFF image, evidence is combined. Zone, UrlSite는 호출 어셈블리에서 상속 되며 HashStrongName는 COFF 어셈블리에서 가져옵니다.Zone, Url and Site are inherited from the calling assembly, and Hash and StrongName are taken from the COFF assembly.

  • Byte[] 매개 변수와 함께 Load 메서드를 사용 하 고 COFF 이미지를 로드 하는 Evidence 경우 제공 된 증명 정보만 사용 됩니다.When you use a Load method with a Byte[] parameter and Evidence to load a COFF image, only the supplied evidence is used. 호출 어셈블리의 증명 정보와 COFF 이미지의 증명 정보는 무시 됩니다.Evidence of the calling assembly and evidence of the COFF image is ignored.

실행 파일 C++ 에 대 한 반사는 BadImageFormatException을 throw 할 수 있습니다.Reflecting on C++ executable files might throw a BadImageFormatException. 이는 C++ 컴파일러가 실행 파일에서 재배치 주소 또는 .reloc 섹션을 제거 하는 경우에 발생할 수 있습니다.This is most likely caused by the C++ compiler stripping the relocation addresses or the .reloc section from your executable file. C++ 실행 파일에 대 한 .reloc 주소를 유지 하려면 링크할 때 /fixed:no를 지정 합니다.To preserve the .reloc address for your C++ executable file, specify /fixed:no when you are linking.

참고

AssemblyName.Name 속성과 AssemblyName.CodeBase 속성이 모두 설정 되어 있는 경우 어셈블리를 로드 하려는 첫 번째 시도는 Assembly.FullName 속성에 의해 반환 되는 버전, 문화권 등을 비롯 한 표시 이름을 사용 합니다.If both the AssemblyName.Name property and the AssemblyName.CodeBase property are set, the first attempt to load the assembly uses the display name (including version, culture, and so on, as returned by the Assembly.FullName property). 파일을 찾을 수 없는 경우 CodeBase를 사용 하 여 어셈블리를 검색 합니다.If the file is not found, CodeBase is used to search for the assembly. CodeBase를 사용 하 여 어셈블리를 찾으면 표시 이름이 어셈블리와 일치 합니다.If the assembly is found using CodeBase, the display name is matched against the assembly. 일치가 실패 하면 FileLoadException이 throw 됩니다.If the match fails, a FileLoadException is thrown.

보안

FileIOPermission
파일이 나 디렉터리에서 읽고 경로 자체의 정보에 액세스 하기 위한입니다.for access to read from a file or directory, and for access to the information in the path itself. 연관 된 열거형: Read, PathDiscoveryAssociated enumerations: Read, PathDiscovery

WebPermission
"file://"로 시작 하지 않는 URI를 읽는 합니다.for reading a URI that does not begin with "file://".

SecurityPermission
증명 정보를 사용 하 여 어셈블리를 로드 합니다.to load an assembly with evidence. 연결 된 열거형: ControlEvidenceAssociated enumeration: ControlEvidence

추가 정보

Load(Byte[], Byte[])

생성된 어셈블리가 들어 있고 경우에 따라 어셈블리에 대한 기호도 포함하는 COFF(공용 개체 파일 형식) 기반 이미지를 사용하여 어셈블리를 로드합니다.Loads the assembly with a common object file format (COFF)-based image containing an emitted assembly, optionally including symbols for the assembly. 이 어셈블리는 호출자의 애플리케이션 도메인에 로드됩니다.The assembly is loaded into the application domain of the caller.

public:
 static System::Reflection::Assembly ^ Load(cli::array <System::Byte> ^ rawAssembly, cli::array <System::Byte> ^ rawSymbolStore);
public static System.Reflection.Assembly Load (byte[] rawAssembly, byte[] rawSymbolStore);
static member Load : byte[] * byte[] -> System.Reflection.Assembly
Public Shared Function Load (rawAssembly As Byte(), rawSymbolStore As Byte()) As Assembly

매개 변수

rawAssembly
Byte[]

내보낸 어셈블리가 포함된 COFF 기반 이미지인 바이트 배열입니다.A byte array that is a COFF-based image containing an emitted assembly.

rawSymbolStore
Byte[]

어셈블리의 기호를 나타내는 원시 바이트가 포함된 바이트 배열입니다.A byte array that contains the raw bytes representing the symbols for the assembly.

반환

로드된 어셈블리입니다.The loaded assembly.

예외

rawAssemblynull인 경우rawAssembly is null.

rawAssembly는 유효한 어셈블리가 아닙니다.rawAssembly is not a valid assembly.

또는-or- 버전 2.0 이상의 공용 언어 런타임이 현재 로드되어 있으며 rawAssembly가 이후 버전으로 컴파일되었습니다.Version 2.0 or later of the common language runtime is currently loaded and rawAssembly was compiled with a later version.

설명

이 메서드를 사용 하 여 로드 된 어셈블리의 신뢰 수준은 호출 하는 어셈블리의 신뢰 수준과 동일 합니다.The trust level of an assembly that is loaded by using this method is the same as the trust level of the calling assembly. 애플리케이션 도메인의 신뢰 수준 사용 하 여 바이트 배열에서 어셈블리를 로드 하려면 사용 된 Load(Byte[], Byte[], SecurityContextSource) 메서드 오버 로드 합니다.To load an assembly from a byte array with the trust level of the application domain, use the Load(Byte[], Byte[], SecurityContextSource) method overload. 바이트 배열을 사용 하는 Load 메서드의 오버 로드에 증명 정보를 사용 하는 방법에 대 한 자세한 내용은 Load(Byte[], Byte[], Evidence) 메서드 오버 로드를 참조 하세요.For more information about the use of evidence with overloads of the Load method that take byte arrays, see the Load(Byte[], Byte[], Evidence) method overload.

실행 파일 C++ 에 대 한 반사는 BadImageFormatException을 throw 할 수 있습니다.Reflecting on C++ executable files might throw a BadImageFormatException. 이는 C++ 컴파일러가 실행 파일에서 재배치 주소 또는 .reloc 섹션을 제거 하는 경우에 발생할 수 있습니다.This is most likely caused by the C++ compiler stripping the relocation addresses or the .reloc section from your executable file. C++ 실행 파일에 대 한 .reloc 주소를 유지 하려면 링크할 때 /fixed:no를 지정 합니다.To preserve the .reloc address for your C++ executable file, specify /fixed:no when you are linking.

이 메서드 오버 로드는 항상 자체 매핑을 사용 하 여 새 Assembly 개체를 만듭니다.Note that this method overload always creates a new Assembly object with its own mapping.

적용 대상