Assembly.LoadFrom Assembly.LoadFrom Assembly.LoadFrom Assembly.LoadFrom Method

정의

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

오버로드

LoadFrom(String, Evidence, Byte[], AssemblyHashAlgorithm) LoadFrom(String, Evidence, Byte[], AssemblyHashAlgorithm) LoadFrom(String, Evidence, Byte[], AssemblyHashAlgorithm) LoadFrom(String, Evidence, Byte[], AssemblyHashAlgorithm)

해당 파일 이름이나 경로가 지정된 어셈블리, 보안 증명 정보, 해시 값 및 해시 알고리즘을 로드합니다.Loads an assembly given its file name or path, security evidence, hash value, and hash algorithm.

LoadFrom(String, Byte[], AssemblyHashAlgorithm) LoadFrom(String, Byte[], AssemblyHashAlgorithm) LoadFrom(String, Byte[], AssemblyHashAlgorithm) LoadFrom(String, Byte[], AssemblyHashAlgorithm)

해당 파일 이름이나 경로가 지정된 어셈블리, 해시 값 및 해시 알고리즘을 로드합니다.Loads an assembly given its file name or path, hash value, and hash algorithm.

LoadFrom(String) LoadFrom(String) LoadFrom(String) LoadFrom(String)

해당 파일 이름이나 경로가 지정된 어셈블리를 로드합니다.Loads an assembly given its file name or path.

LoadFrom(String, Evidence) LoadFrom(String, Evidence) LoadFrom(String, Evidence) LoadFrom(String, Evidence)

해당 파일 이름이나 경로가 지정된 어셈블리를 로드하고 보안 증명을 제공합니다.Loads an assembly given its file name or path and supplying security evidence.

설명

.NET Framework 4 부터는 원격 위치에서 로드 된 어셈블리에서 코드를 실행 하는 기능은 사용 되지 기본적으로 호출 합니다 LoadFrom 메서드가 throw를 FileLoadException입니다.Starting with .NET Framework 4, the ability to execute code in assemblies loaded from remote locations is disabled by default, and the call to the LoadFrom method throws a FileLoadException. 에 어셈블리를 로드 하 고 해당 코드를 실행 하거나 다음을 수행 해야 합니다.To load the assembly and execute its code, you must either:

LoadFrom(String, Evidence, Byte[], AssemblyHashAlgorithm) LoadFrom(String, Evidence, Byte[], AssemblyHashAlgorithm) LoadFrom(String, Evidence, Byte[], AssemblyHashAlgorithm) LoadFrom(String, Evidence, Byte[], AssemblyHashAlgorithm)

경고

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

해당 파일 이름이나 경로가 지정된 어셈블리, 보안 증명 정보, 해시 값 및 해시 알고리즘을 로드합니다.Loads an assembly given its file name or path, security evidence, hash value, and hash algorithm.

public:
 static System::Reflection::Assembly ^ LoadFrom(System::String ^ assemblyFile, System::Security::Policy::Evidence ^ securityEvidence, cli::array <System::Byte> ^ hashValue, System::Configuration::Assemblies::AssemblyHashAlgorithm hashAlgorithm);
[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 LoadFrom which does not take an Evidence parameter. See http://go.microsoft.com/fwlink/?LinkID=155570 for more information.")]
public static System.Reflection.Assembly LoadFrom (string assemblyFile, System.Security.Policy.Evidence securityEvidence, byte[] hashValue, System.Configuration.Assemblies.AssemblyHashAlgorithm hashAlgorithm);
static member LoadFrom : string * System.Security.Policy.Evidence * byte[] * System.Configuration.Assemblies.AssemblyHashAlgorithm -> System.Reflection.Assembly
Public Shared Function LoadFrom (assemblyFile As String, securityEvidence As Evidence, hashValue As Byte(), hashAlgorithm As AssemblyHashAlgorithm) As Assembly

매개 변수

assemblyFile
String String String String

어셈블리 매니페스트가 포함된 파일의 이름 또는 경로입니다.The name or path of the file that contains the manifest of the assembly.

securityEvidence
Evidence Evidence Evidence Evidence

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

hashValue
Byte[]

계산된 해시 코드의 값입니다.The value of the computed hash code.

hashAlgorithm
AssemblyHashAlgorithm AssemblyHashAlgorithm AssemblyHashAlgorithm AssemblyHashAlgorithm

파일을 해시하고 강력한 이름을 생성하는 데 사용된 해시 알고리즘입니다.The hash algorithm used for hashing files and for generating the strong name.

반환

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

예외

assemblyFilenull입니다.assemblyFile is null.

assemblyFile이 없거나 로드하려는 모듈이 파일 확장명을 지정하지 않습니다.assemblyFile is not found, or the module you are trying to load does not specify a filename extension.

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

또는-or- securityEvidence가 모호하며 올바르지 않은 것으로 확인되었습니다.The securityEvidence is not ambiguous and is determined to be invalid.

또는-or-

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

assemblyFile이 유효한 어셈블리가 아닙니다. 예를 들어, 64비트 프로세스의 32비트 어셈블리입니다.assemblyFile is not a valid assembly; for example, a 32-bit assembly in a 64-bit process. 자세한 정보는 예외 항목을 참조하세요.See the exception topic for more information.

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

"file://"로 시작하지 않는 Codebase가 필수 WebPermission 없이 지정되었습니다.A codebase that does not start with "file://" was specified without the required WebPermission.

assemblyFile 매개 변수가 빈 문자열("")입니다.The assemblyFile parameter is an empty string ("").

어셈블리 이름이 시스템 정의 최대 길이를 초과합니다.The assembly name exceeds the system-defined maximum length.

설명

assemblyFile 매개 변수 이스케이프 문자가 없는 URI 참조 해야 합니다.The assemblyFile parameter must refer to a URI without escape characters. 이 메서드는 URI에서 모든 잘못 된 문자가 이스케이프 문자를 제공합니다.This method supplies escape characters for all invalid characters in the URI.

참고

파일 전송 프로토콜 (FTP) 지원 되지 않습니다.File transfer protocol (FTP) is not supported. 에 대 한 제공 된 URI assemblyFile FTP 주소를 사용 하는 어셈블리가 로드 되지 않습니다.If the URI supplied for assemblyFile is an FTP address, the assembly is not loaded. 예외가 throw되지 않습니다.No exception is thrown.

assemblyFile 현재 디렉터리에 절대적 이거나 상대적 않을 어셈블리는 호출자의 도메인에 로드 합니다.assemblyFile may be absolute or relative to the current directory, and the assembly is loaded into the domain of the caller.

어셈블리는 세 개의 컨텍스트 중 하나로 로드할 수 있습니다 또는 컨텍스트 없이 로드 될 수 있습니다.Assemblies can be loaded into one of three contexts, or can be loaded without context:

  • 로드 컨텍스트를 검색 하 여 찾은 어셈블리가 포함: GAC에 호스트 어셈블리에서는 런타임 호스트 되는 경우 또는 저장 된 ApplicationBasePrivateBinPath 애플리케이션 도메인입니다.The load context contains assemblies found by probing: in the GAC, in a host assembly store if the runtime is hosted, or in the ApplicationBase and PrivateBinPath of the application domain. Load 메서드의 대부분 오버로드는 어셈블리 이 컨텍스트에 로드합니다.Most overloads of the Load method load assemblies into this context.

  • 로드 컨텍스트를 검색 하 여 검색 된 디렉터리에 포함 되지 않은 경로 제공 하는 어셈블리를 포함 합니다.The load-from context contains assemblies for which the user provided a path not included in the directories searched by probing. LoadFrom, CreateInstanceFromExecuteAssembly는 경로로 로드되는 메서드의 예제입니다.LoadFrom, CreateInstanceFrom, and ExecuteAssembly are examples of methods that load by path.

    경우.NET Framework 4부터의 URI assemblyFile 원격 위치를 지정 어셈블리 로드는 기본적으로 사용 하지 않도록 설정 하며 LoadFrom 메서드가 throw를 FileLoadException입니다.Starting with .NET Framework 4, if the URI of assemblyFile specifies a remote location, assembly loading is disabled by default, and the LoadFrom method throws a FileLoadException. 원격 위치에서 로드 된 코드의 실행을 사용 하도록 설정 하려면 사용 합니다 <loadFromRemoteSources> 구성 요소입니다.To enable execution of code loaded from remote locations, you can use the <loadFromRemoteSources> configuration element.

  • 리플렉션 전용 컨텍스트에 로드 된 어셈블리를 포함 합니다 ReflectionOnlyLoadReflectionOnlyLoadFrom 메서드, 이러한 코드 컨텍스트를 실행할 수 없습니다.The reflection-only context contains assemblies loaded with the ReflectionOnlyLoad and ReflectionOnlyLoadFrom methods; code in these contexts cannot be executed.

  • 사용자 생성 된 어셈블리를 찾을 수, 하는 경우 모든 컨텍스트에서 아닙니다.If the user generated or found the assembly, it is not in any context. 이 오버 로드를 사용 하 여 로드 된 어셈블리에 적용 됩니다는 Load 와 어셈블리를 포함 하는 바이트 배열을 지정 하 고, 리플렉션을 사용 하 여 만든 임시 동적 어셈블리 내보내기를 하 고, 디스크에 저장 되지 메서드입니다.This applies to assemblies loaded using overloads of the Load method that specify a byte array containing an assembly, and to transient dynamic assemblies created with reflection emit and not saved to disk.

로드 컨텍스트 검색에 포함 되지 않은 경로에서 로드 되도록 어셈블리 있으며 아직 컨텍스트 경로 정보를 유지 하기 때문에 해당 경로에 종속성을 허용 합니다.The load-from context allows an assembly to be loaded from a path not included in probing, and yet allows dependencies on that path to be found and loaded because the path information is maintained by the context.

LoadFrom 메서드가 다음과 같은 단점이 있습니다.The LoadFrom method has the following disadvantages. 대신 Load을 사용하는 것이 좋습니다.Consider using Load instead.

  • 같은 ID를 가진 어셈블리가 이미 로드되어 있으면 다른 경로가 지정된 경우에도 LoadFrom은 로드된 어셈블리를 반환합니다.If an assembly with the same identity is already loaded, LoadFrom returns the loaded assembly even if a different path was specified.

  • 어셈블리를 사용 하 여 로드 LoadFrom, 로드 컨텍스트에 어셈블리 표시 이름으로 동일한 어셈블리를 로드 하려고 시도 하는 나중에 로드 하려고 하면 실패 합니다.If an assembly is loaded with LoadFrom, and later an assembly in the load context attempts to load the same assembly by display name, the load attempt fails. 어셈블리가 deserialize되면 이 문제가 발생할 수 있습니다.This can occur when an assembly is deserialized.

  • 어셈블리를 사용 하 여 로드 LoadFrom, id가 같지만 다른 위치를 사용 하 여 어셈블리 검색 경로 포함 되어는 InvalidCastException, MissingMethodException, 또는 기타 예기치 않은 동작이 발생할 수 있습니다.If an assembly is loaded with LoadFrom, and the probing path includes an assembly with the same identity but a different location, an InvalidCastException, MissingMethodException, or other unexpected behavior can occur.

  • LoadFrom은 지정된 경로에서 FileIOPermissionAccess.ReadFileIOPermissionAccess.PathDiscovery 또는 WebPermission을 요구합니다.LoadFrom demands FileIOPermissionAccess.Read and FileIOPermissionAccess.PathDiscovery, or WebPermission, on the specified path.

  • 네이티브 이미지에 대 한 있으면 assemblyFile, 사용 되지 않습니다.If a native image exists for assemblyFile, it is not used. 어셈블리가는 도메인 중립적으로 로드할 수 없습니다.The assembly cannot be loaded as domain neutral.

  • .NET Framework 버전 1.0 및 1.1에서는 정책이 적용 되지 않습니다.In the .NET Framework version 1.0 and 1.1, policy is not applied.

어셈블리에 대한 특정 권한 부여 여부는 증명 정보를 바탕으로 합니다.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:

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

  • 사용 하는 경우는 LoadFrom 메서드는 Evidence 매개 변수를 증거의 조각을 병합 됩니다.When you use a LoadFrom method with an Evidence parameter, pieces of evidence are merged. 인수로 제공 하는 증거의 조각을 LoadFrom 메서드는 로더에 의해 제공 된 증명 정보를 대체 합니다.Pieces of evidence supplied as an argument to the LoadFrom method supersede pieces of evidence supplied by the loader.

  • 한 번에이 메서드를 호출 하면 동일한 어셈블리에 있지만 지정 된 다른 증명, 공용 언어 런타임에서 throw 하지 않습니다는 FileLoadException 같음 및 다른 증명 사양의 무결성을 확인할 수 없으므로 합니다.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.

  • 사용 하는 경우는 LoadFrom 메서드는 Byte[] 공용 개체 파일 (COFF) 형식 이미지를 증명 정보를 로드 하려면 매개 변수 결합 됩니다.When you use a LoadFrom method with a Byte[] parameter to load a common object file format (COFF) image, evidence is combined. ZoneUrl 하 고 Site 호출 하는 어셈블리에서 상속 됩니다 및 HashStrongName COFF 어셈블리에서 수행 됩니다.Zone, Url and Site are inherited from the calling assembly, and Hash and StrongName are taken from the COFF assembly.

  • 사용 하는 경우는 LoadFrom 메서드를 Byte[] 매개 변수 및 Evidence COFF 이미지를 로드 하려면 제공 된 증명 정보를 사용 합니다.When you use a LoadFrom 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.

보안

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

FileIOPermission
"file://"로 시작 하는 URI를 읽는 합니다.for reading a URI that begins with "file://". 연결 된 열거형: ReadAssociated enumeration: Read

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

LoadFrom(String, Byte[], AssemblyHashAlgorithm) LoadFrom(String, Byte[], AssemblyHashAlgorithm) LoadFrom(String, Byte[], AssemblyHashAlgorithm) LoadFrom(String, Byte[], AssemblyHashAlgorithm)

해당 파일 이름이나 경로가 지정된 어셈블리, 해시 값 및 해시 알고리즘을 로드합니다.Loads an assembly given its file name or path, hash value, and hash algorithm.

public:
 static System::Reflection::Assembly ^ LoadFrom(System::String ^ assemblyFile, cli::array <System::Byte> ^ hashValue, System::Configuration::Assemblies::AssemblyHashAlgorithm hashAlgorithm);
public static System.Reflection.Assembly LoadFrom (string assemblyFile, byte[] hashValue, System.Configuration.Assemblies.AssemblyHashAlgorithm hashAlgorithm);
static member LoadFrom : string * byte[] * System.Configuration.Assemblies.AssemblyHashAlgorithm -> System.Reflection.Assembly
Public Shared Function LoadFrom (assemblyFile As String, hashValue As Byte(), hashAlgorithm As AssemblyHashAlgorithm) As Assembly

매개 변수

assemblyFile
String String String String

어셈블리 매니페스트가 포함된 파일의 이름 또는 경로입니다.The name or path of the file that contains the manifest of the assembly.

hashValue
Byte[]

계산된 해시 코드의 값입니다.The value of the computed hash code.

hashAlgorithm
AssemblyHashAlgorithm AssemblyHashAlgorithm AssemblyHashAlgorithm AssemblyHashAlgorithm

파일을 해시하고 강력한 이름을 생성하는 데 사용된 해시 알고리즘입니다.The hash algorithm used for hashing files and for generating the strong name.

반환

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

예외

assemblyFilenull인 경우assemblyFile is null.

assemblyFile이 없거나 로드하려는 모듈이 파일 이름 확장명을 지정하지 않습니다.assemblyFile is not found, or the module you are trying to load does not specify a file name extension.

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

또는-or-

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

assemblyFile이 유효한 어셈블리가 아닙니다. 예를 들어, 64비트 프로세스의 32비트 어셈블리입니다.assemblyFile is not a valid assembly; for example, a 32-bit assembly in a 64-bit process. 자세한 정보는 예외 항목을 참조하세요.See the exception topic for more information.

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

"file://"로 시작하지 않는 Codebase가 필수 WebPermission 없이 지정되었습니다.A codebase that does not start with "file://" was specified without the required WebPermission.

assemblyFile 매개 변수가 빈 문자열("")입니다.The assemblyFile parameter is an empty string ("").

어셈블리 이름이 시스템 정의 최대 길이를 초과합니다.The assembly name exceeds the system-defined maximum length.

설명

assemblyFile 매개 변수 이스케이프 문자가 없는 URI 참조 해야 합니다.The assemblyFile parameter must refer to a URI without escape characters. 이 메서드는 URI에서 모든 잘못 된 문자가 이스케이프 문자를 제공합니다.This method supplies escape characters for all invalid characters in the URI.

참고

파일 전송 프로토콜 (FTP) 지원 되지 않습니다.File transfer protocol (FTP) is not supported. 에 대 한 제공 된 URI assemblyFile FTP 주소를 사용 하는 어셈블리가 로드 되지 않습니다.If the URI supplied for assemblyFile is an FTP address, the assembly is not loaded. 예외가 throw되지 않습니다.No exception is thrown.

assemblyFile 현재 디렉터리에 절대적 이거나 상대적 않을 어셈블리는 호출자의 도메인에 로드 합니다.assemblyFile may be absolute or relative to the current directory, and the assembly is loaded into the domain of the caller.

어셈블리는 세 개의 컨텍스트 중 하나로 로드할 수 있습니다 또는 컨텍스트 없이 로드 될 수 있습니다.Assemblies can be loaded into one of three contexts, or can be loaded without context:

  • 로드 컨텍스트를 검색 하 여 찾은 어셈블리가 포함: 전역 어셈블리 캐시에 호스트 어셈블리에서는 런타임 호스트 되는 경우 또는 저장 된 ApplicationBasePrivateBinPath 애플리케이션 도메인입니다.The load context contains assemblies found by probing: in the global assembly cache, in a host assembly store if the runtime is hosted, or in the ApplicationBase and PrivateBinPath of the application domain. Load 메서드의 대부분 오버로드는 어셈블리 이 컨텍스트에 로드합니다.Most overloads of the Load method load assemblies into this context.

  • 로드 컨텍스트는 사용자 검색에 포함 되지 않은 경로 제공 하는 어셈블리를 포함 합니다.The load-from context contains assemblies for which the user provided a path that is not included in probing. LoadFrom, CreateInstanceFromExecuteAssembly는 경로로 로드되는 메서드의 예제입니다.LoadFrom, CreateInstanceFrom, and ExecuteAssembly are examples of methods that load by path.

    경우.NET Framework 4부터의 URI assemblyFile 원격 위치를 지정 어셈블리 로드는 기본적으로 사용 하지 않도록 설정 하며 LoadFrom 메서드가 throw를 FileLoadException입니다.Starting with .NET Framework 4, if the URI of assemblyFile specifies a remote location, assembly loading is disabled by default, and the LoadFrom method throws a FileLoadException. 원격 위치에서 로드 된 코드의 실행을 사용 하도록 설정 하려면 사용 합니다 <loadFromRemoteSources> 구성 요소입니다.To enable execution of code loaded from remote locations, you can use the <loadFromRemoteSources> configuration element.

  • 리플렉션 전용 컨텍스트에 로드 된 어셈블리를 포함 합니다 ReflectionOnlyLoadReflectionOnlyLoadFrom 메서드, 이러한 코드 컨텍스트를 실행할 수 없습니다.The reflection-only context contains assemblies loaded with the ReflectionOnlyLoad and ReflectionOnlyLoadFrom methods; code in these contexts cannot be executed.

  • 사용자 생성 된 어셈블리를 찾을 수, 하는 경우 모든 컨텍스트에서 아닙니다.If the user generated or found the assembly, it is not in any context. 이 오버 로드를 사용 하 여 로드 된 어셈블리에 적용 됩니다는 Load 와 어셈블리를 포함 하는 바이트 배열을 지정 하 고, 리플렉션을 사용 하 여 만든 임시 동적 어셈블리 내보내기를 하 고, 디스크에 저장 되지 메서드입니다.This applies to assemblies loaded using overloads of the Load method that specify a byte array containing an assembly, and to transient dynamic assemblies created with reflection emit and not saved to disk.

로드 컨텍스트 검색에 포함 되지 않은 경로에서 로드 되도록 어셈블리 있으며 아직 컨텍스트 경로 정보를 유지 하기 때문에 해당 경로에 종속성을 허용 합니다.The load-from context allows an assembly to be loaded from a path that is not included in probing, and yet allows dependencies on that path to be found and loaded because the path information is maintained by the context.

LoadFrom 메서드가 다음과 같은 단점이 있습니다.The LoadFrom method has the following disadvantages. 대신 Load을 사용하는 것이 좋습니다.Consider using Load instead.

  • 같은 ID를 가진 어셈블리가 이미 로드되어 있으면 다른 경로가 지정된 경우에도 LoadFrom은 로드된 어셈블리를 반환합니다.If an assembly with the same identity is already loaded, LoadFrom returns the loaded assembly even if a different path was specified.

  • 어셈블리를 사용 하 여 로드 LoadFrom, 로드 컨텍스트에 어셈블리 표시 이름으로 동일한 어셈블리를 로드 하려고 시도 하는 나중에 로드 하려고 하면 실패 합니다.If an assembly is loaded with LoadFrom, and later an assembly in the load context attempts to load the same assembly by display name, the load attempt fails. 어셈블리가 deserialize되면 이 문제가 발생할 수 있습니다.This can occur when an assembly is deserialized.

  • 어셈블리를 사용 하 여 로드 LoadFrom, id가 같지만 다른 위치를 사용 하 여 어셈블리 검색 경로 포함 되어는 InvalidCastException, MissingMethodException, 또는 기타 예기치 않은 동작이 발생할 수 있습니다.If an assembly is loaded with LoadFrom, and the probing path includes an assembly with the same identity but a different location, an InvalidCastException, MissingMethodException, or other unexpected behavior can occur.

  • LoadFrom은 지정된 경로에서 FileIOPermissionAccess.ReadFileIOPermissionAccess.PathDiscovery 또는 WebPermission을 요구합니다.LoadFrom demands FileIOPermissionAccess.Read and FileIOPermissionAccess.PathDiscovery, or WebPermission, on the specified path.

  • 네이티브 이미지에 대 한 있으면 assemblyFile, 사용 되지 않습니다.If a native image exists for assemblyFile, it is not used. 어셈블리는 도메인 중립적으로 로드될 수 없습니다.The assembly cannot be loaded as domain-neutral.

어셈블리 로더를 제공 하는 증명 정보를 사용 하 여 로드 됩니다.The assembly is loaded with the evidence that the loader supplies.

보안

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

FileIOPermission
"file://"로 시작 하는 URI를 읽는 합니다.for reading a URI that begins with "file://". 연결 된 열거형: ReadAssociated enumeration: Read

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

LoadFrom(String) LoadFrom(String) LoadFrom(String) LoadFrom(String)

해당 파일 이름이나 경로가 지정된 어셈블리를 로드합니다.Loads an assembly given its file name or path.

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

매개 변수

assemblyFile
String String String String

어셈블리 매니페스트가 포함된 파일의 이름 또는 경로입니다.The name or path of the file that contains the manifest of the assembly.

반환

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

예외

assemblyFilenull인 경우assemblyFile is null.

assemblyFile이 없거나 로드하려는 모듈이 파일 확장명을 지정하지 않습니다.assemblyFile is not found, or the module you are trying to load does not specify a filename extension.

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

또는-or-

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

assemblyFile이 유효한 어셈블리가 아닙니다. 예를 들어, 64비트 프로세스의 32비트 어셈블리입니다.assemblyFile is not a valid assembly; for example, a 32-bit assembly in a 64-bit process. 자세한 정보는 예외 항목을 참조하세요.See the exception topic for more information.

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

"file://"로 시작하지 않는 Codebase가 필수 WebPermission 없이 지정되었습니다.A codebase that does not start with "file://" was specified without the required WebPermission.

assemblyFile 매개 변수가 빈 문자열("")입니다.The assemblyFile parameter is an empty string ("").

어셈블리 이름이 시스템 정의 최대 길이를 초과합니다.The assembly name exceeds the system-defined maximum length.

예제

다음 예제에서는 해당 파일 이름이 나 경로가 지정 된 어셈블리를 로드 합니다.The following example loads an assembly given its file name or path.

Assembly^ SampleAssembly;
SampleAssembly = Assembly::LoadFrom( "c:\\Sample.Assembly.dll" );
// Obtain a reference to a method known to exist in assembly.
MethodInfo^ Method = SampleAssembly->GetTypes()[ 0 ]->GetMethod( "Method1" );
// Obtain a reference to the parameters collection of the MethodInfo instance.
array<ParameterInfo^>^ Params = Method->GetParameters();
// Display information about method parameters.
// Param = sParam1
//   Type = System::String
//   Position = 0
//   Optional=False
for each ( ParameterInfo^ Param in Params )
{
   Console::WriteLine( "Param= {0}", Param->Name );
   Console::WriteLine( "  Type= {0}", Param->ParameterType );
   Console::WriteLine( "  Position= {0}", Param->Position );
   Console::WriteLine( "  Optional= {0}", Param->IsOptional );
}
Assembly SampleAssembly;
SampleAssembly = Assembly.LoadFrom("c:\\Sample.Assembly.dll");
// Obtain a reference to a method known to exist in assembly.
MethodInfo Method = SampleAssembly.GetTypes()[0].GetMethod("Method1");
// Obtain a reference to the parameters collection of the MethodInfo instance.
ParameterInfo[] Params = Method.GetParameters();
// Display information about method parameters.
// Param = sParam1
//   Type = System.String
//   Position = 0
//   Optional=False
foreach (ParameterInfo Param in Params)
{
    Console.WriteLine("Param=" + Param.Name.ToString());
    Console.WriteLine("  Type=" + Param.ParameterType.ToString());
    Console.WriteLine("  Position=" + Param.Position.ToString());
    Console.WriteLine("  Optional=" + Param.IsOptional.ToString());
}
Dim SampleAssembly As [Assembly]
SampleAssembly = [Assembly].LoadFrom("c:\Sample.Assembly.dll")
' Obtain a reference to a method known to exist in assembly.
Dim Method As MethodInfo = SampleAssembly.GetTypes()(0).GetMethod("Method1")
' Obtain a reference to the parameters collection of the MethodInfo instance.
Dim Params As ParameterInfo() = Method.GetParameters()
' Display information about method parameters.
' Param = sParam1
'   Type = System.String
'   Position = 0
'   Optional=False
For Each Param As ParameterInfo In Params
    Console.WriteLine(("Param=" + Param.Name.ToString()))
    Console.WriteLine(("  Type=" + Param.ParameterType.ToString()))
    Console.WriteLine(("  Position=" + Param.Position.ToString()))
    Console.WriteLine(("  Optional=" + Param.IsOptional.ToString()))
Next 

설명

assemblyFile 매개 변수 이스케이프 문자가 없는 URI 참조 해야 합니다.The assemblyFile parameter must refer to a URI without escape characters. 이 메서드는 URI에서 모든 잘못 된 문자가 이스케이프 문자를 제공합니다.This method supplies escape characters for all invalid characters in the URI.

참고

파일 전송 프로토콜 (FTP) 지원 되지 않습니다.File transfer protocol (FTP) is not supported. 에 대 한 제공 된 URI assemblyFile FTP 주소를 사용 하는 어셈블리가 로드 되지 않습니다.If the URI supplied for assemblyFile is an FTP address, the assembly is not loaded. 예외가 throw되지 않습니다.No exception is thrown.

assemblyFile 현재 디렉터리에 절대적 이거나 상대적 않을 어셈블리는 호출자의 도메인에 로드 합니다.assemblyFile may be absolute or relative to the current directory, and the assembly is loaded into the domain of the caller.

어셈블리는 세 개의 컨텍스트 중 하나로 로드할 수 있습니다 또는 컨텍스트 없이 로드 될 수 있습니다.Assemblies can be loaded into one of three contexts, or can be loaded without context:

  • 로드 컨텍스트를 검색 하 여 찾은 어셈블리가 포함: GAC에 호스트 어셈블리에서는 런타임 호스트 되는 경우 또는 저장 된 ApplicationBasePrivateBinPath 애플리케이션 도메인입니다.The load context contains assemblies found by probing: in the GAC, in a host assembly store if the runtime is hosted, or in the ApplicationBase and PrivateBinPath of the application domain. Load 메서드의 대부분 오버로드는 어셈블리 이 컨텍스트에 로드합니다.Most overloads of the Load method load assemblies into this context.

  • 로드 컨텍스트를 검색 하 여 검색 된 디렉터리에 포함 되지 않은 경로 제공 하는 어셈블리를 포함 합니다.The load-from context contains assemblies for which the user provided a path not included in the directories searched by probing. LoadFrom, CreateInstanceFromExecuteAssembly는 경로로 로드되는 메서드의 예제입니다.LoadFrom, CreateInstanceFrom, and ExecuteAssembly are examples of methods that load by path.

    경우.NET Framework 4부터의 URI assemblyFile 원격 위치를 지정 어셈블리 로드는 기본적으로 사용 하지 않도록 설정 하며 LoadFrom 메서드가 throw를 FileLoadException입니다.Starting with .NET Framework 4, if the URI of assemblyFile specifies a remote location, assembly loading is disabled by default, and the LoadFrom method throws a FileLoadException. 원격 위치에서 로드 된 코드의 실행을 사용 하도록 설정 하려면 사용 합니다 <loadFromRemoteSources> 구성 요소입니다.To enable execution of code loaded from remote locations, you can use the <loadFromRemoteSources> configuration element.

  • 리플렉션 전용 컨텍스트에 로드 된 어셈블리를 포함 합니다 ReflectionOnlyLoadReflectionOnlyLoadFrom 메서드, 이러한 코드 컨텍스트를 실행할 수 없습니다.The reflection-only context contains assemblies loaded with the ReflectionOnlyLoad and ReflectionOnlyLoadFrom methods; code in these contexts cannot be executed.

  • 사용자 생성 된 어셈블리를 찾을 수, 하는 경우 모든 컨텍스트에서 아닙니다.If the user generated or found the assembly, it is not in any context. 이 오버 로드를 사용 하 여 로드 된 어셈블리에 적용 됩니다는 Load 와 어셈블리를 포함 하는 바이트 배열을 지정 하 고, 리플렉션을 사용 하 여 만든 임시 동적 어셈블리 내보내기를 하 고, 디스크에 저장 되지 메서드입니다.This applies to assemblies loaded using overloads of the Load method that specify a byte array containing an assembly, and to transient dynamic assemblies created with reflection emit and not saved to disk.

로드 컨텍스트 검색에 포함 되지 않은 경로에서 로드 되도록 어셈블리 있으며 아직 컨텍스트 경로 정보를 유지 하기 때문에 해당 경로에 종속성을 허용 합니다.The load-from context allows an assembly to be loaded from a path not included in probing, and yet allows dependencies on that path to be found and loaded because the path information is maintained by the context.

LoadFrom 메서드가 다음과 같은 단점이 있습니다.The LoadFrom method has the following disadvantages. 대신 Load을 사용하는 것이 좋습니다.Consider using Load instead.

  • 같은 ID를 가진 어셈블리가 이미 로드되어 있으면 다른 경로가 지정된 경우에도 LoadFrom은 로드된 어셈블리를 반환합니다.If an assembly with the same identity is already loaded, LoadFrom returns the loaded assembly even if a different path was specified.

  • 어셈블리를 사용 하 여 로드 LoadFrom, 로드 컨텍스트에 어셈블리 표시 이름으로 동일한 어셈블리를 로드 하려고 시도 하는 나중에 로드 하려고 하면 실패 합니다.If an assembly is loaded with LoadFrom, and later an assembly in the load context attempts to load the same assembly by display name, the load attempt fails. 어셈블리가 deserialize 될 때 발생할 수 있습니다.This can occur when an assembly is de-serialized.

  • 어셈블리를 사용 하 여 로드 LoadFrom, id가 같지만 다른 위치를 사용 하 여 어셈블리 검색 경로 포함 되어는 InvalidCastException, MissingMethodException, 또는 기타 예기치 않은 동작이 발생할 수 있습니다.If an assembly is loaded with LoadFrom, and the probing path includes an assembly with the same identity but a different location, an InvalidCastException, MissingMethodException, or other unexpected behavior can occur.

  • LoadFrom은 지정된 경로에서 FileIOPermissionAccess.ReadFileIOPermissionAccess.PathDiscovery 또는 WebPermission을 요구합니다.LoadFrom demands FileIOPermissionAccess.Read and FileIOPermissionAccess.PathDiscovery, or WebPermission, on the specified path.

  • 네이티브 이미지에 대 한 있으면 assemblyFile, 사용 되지 않습니다.If a native image exists for assemblyFile, it is not used. 어셈블리가는 도메인 중립적으로 로드할 수 없습니다.The assembly cannot be loaded as domain neutral.

  • .NET Framework 버전 1.0 및 1.1에서는 정책이 적용 되지 않습니다.In the .NET Framework version 1.0 and 1.1, policy is not applied.

보안

FileIOPermission
"file://"로 시작 하는 URI를 읽는 합니다.for reading a URI that begins with "file://". 연결 된 열거형: ReadAssociated enumeration: Read

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

LoadFrom(String, Evidence) LoadFrom(String, Evidence) LoadFrom(String, Evidence) LoadFrom(String, Evidence)

경고

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

해당 파일 이름이나 경로가 지정된 어셈블리를 로드하고 보안 증명을 제공합니다.Loads an assembly given its file name or path and supplying security evidence.

public:
 static System::Reflection::Assembly ^ LoadFrom(System::String ^ assemblyFile, 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 LoadFrom which does not take an Evidence parameter. See http://go.microsoft.com/fwlink/?LinkID=155570 for more information.")]
public static System.Reflection.Assembly LoadFrom (string assemblyFile, System.Security.Policy.Evidence securityEvidence);
static member LoadFrom : string * System.Security.Policy.Evidence -> System.Reflection.Assembly
Public Shared Function LoadFrom (assemblyFile As String, securityEvidence As Evidence) As Assembly

매개 변수

assemblyFile
String String String String

어셈블리 매니페스트가 포함된 파일의 이름 또는 경로입니다.The name or path of the file that contains the manifest of the assembly.

securityEvidence
Evidence Evidence Evidence Evidence

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

반환

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

예외

assemblyFilenull입니다.assemblyFile is null.

assemblyFile이 없거나 로드하려는 모듈이 파일 확장명을 지정하지 않습니다.assemblyFile is not found, or the module you are trying to load does not specify a filename extension.

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

또는-or- securityEvidence가 모호하며 올바르지 않은 것으로 확인되었습니다.The securityEvidence is not ambiguous and is determined to be invalid.

또는-or-

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

assemblyFile이 유효한 어셈블리가 아닙니다. 예를 들어, 64비트 프로세스의 32비트 어셈블리입니다.assemblyFile is not a valid assembly; for example, a 32-bit assembly in a 64-bit process. 자세한 정보는 예외 항목을 참조하세요.See the exception topic for more information.

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

"file://"로 시작하지 않는 Codebase가 필수 WebPermission 없이 지정되었습니다.A codebase that does not start with "file://" was specified without the required WebPermission.

assemblyFile 매개 변수가 빈 문자열("")입니다.The assemblyFile parameter is an empty string ("").

어셈블리 이름이 시스템 정의 최대 길이를 초과합니다.The assembly name exceeds the system-defined maximum length.

설명

assemblyFile 매개 변수 이스케이프 문자가 없는 URI 참조 해야 합니다.The assemblyFile parameter must refer to a URI without escape characters. 이 메서드는 URI에서 모든 잘못 된 문자가 이스케이프 문자를 제공합니다.This method supplies escape characters for all invalid characters in the URI.

참고

파일 전송 프로토콜 (FTP) 지원 되지 않습니다.File transfer protocol (FTP) is not supported. 에 대 한 제공 된 URI assemblyFile FTP 주소를 사용 하는 어셈블리가 로드 되지 않습니다.If the URI supplied for assemblyFile is an FTP address, the assembly is not loaded. 예외가 throw되지 않습니다.No exception is thrown.

assemblyFile 현재 디렉터리에 절대적 이거나 상대적 않을 어셈블리는 호출자의 도메인에 로드 합니다.assemblyFile may be absolute or relative to the current directory, and the assembly is loaded into the domain of the caller.

어셈블리는 세 개의 컨텍스트 중 하나로 로드할 수 있습니다 또는 컨텍스트 없이 로드 될 수 있습니다.Assemblies can be loaded into one of three contexts, or can be loaded without context:

  • 로드 컨텍스트를 검색 하 여 찾은 어셈블리가 포함: GAC에 호스트 어셈블리에서는 런타임 호스트 되는 경우 또는 저장 된 ApplicationBasePrivateBinPath 애플리케이션 도메인입니다.The load context contains assemblies found by probing: in the GAC, in a host assembly store if the runtime is hosted, or in the ApplicationBase and PrivateBinPath of the application domain. Load 메서드의 대부분 오버로드는 어셈블리 이 컨텍스트에 로드합니다.Most overloads of the Load method load assemblies into this context.

  • 로드 컨텍스트를 검색 하 여 검색 된 디렉터리에 포함 되지 않은 경로 제공 하는 어셈블리를 포함 합니다.The load-from context contains assemblies for which the user provided a path not included in the directories searched by probing. LoadFrom, CreateInstanceFromExecuteAssembly는 경로로 로드되는 메서드의 예제입니다.LoadFrom, CreateInstanceFrom, and ExecuteAssembly are examples of methods that load by path.

    경우.NET Framework 4부터의 URI assemblyFile 원격 위치를 지정 어셈블리 로드는 기본적으로 사용 하지 않도록 설정 하며 LoadFrom 메서드가 throw를 FileLoadException입니다.Starting with .NET Framework 4, if the URI of assemblyFile specifies a remote location, assembly loading is disabled by default, and the LoadFrom method throws a FileLoadException. 원격 위치에서 로드 된 코드의 실행을 사용 하도록 설정 하려면 사용 합니다 <loadFromRemoteSources> 구성 요소입니다.To enable execution of code loaded from remote locations, you can use the <loadFromRemoteSources> configuration element.

  • 리플렉션 전용 컨텍스트에 로드 된 어셈블리를 포함 합니다 ReflectionOnlyLoadReflectionOnlyLoadFrom 메서드, 이러한 코드 컨텍스트를 실행할 수 없습니다.The reflection-only context contains assemblies loaded with the ReflectionOnlyLoad and ReflectionOnlyLoadFrom methods; code in these contexts cannot be executed.

  • 사용자 생성 된 어셈블리를 찾을 수, 하는 경우 모든 컨텍스트에서 아닙니다.If the user generated or found the assembly, it is not in any context. 이 오버 로드를 사용 하 여 로드 된 어셈블리에 적용 됩니다는 Load 와 어셈블리를 포함 하는 바이트 배열을 지정 하 고, 리플렉션을 사용 하 여 만든 임시 동적 어셈블리 내보내기를 하 고, 디스크에 저장 되지 메서드입니다.This applies to assemblies loaded using overloads of the Load method that specify a byte array containing an assembly, and to transient dynamic assemblies created with reflection emit and not saved to disk.

로드 컨텍스트 검색에 포함 되지 않은 경로에서 로드 되도록 어셈블리 있으며 아직 컨텍스트 경로 정보를 유지 하기 때문에 해당 경로에 종속성을 허용 합니다.The load-from context allows an assembly to be loaded from a path not included in probing, and yet allows dependencies on that path to be found and loaded because the path information is maintained by the context.

LoadFrom 메서드가 다음과 같은 단점이 있습니다.The LoadFrom method has the following disadvantages. 대신 Load을 사용하는 것이 좋습니다.Consider using Load instead.

  • 같은 ID를 가진 어셈블리가 이미 로드되어 있으면 다른 경로가 지정된 경우에도 LoadFrom은 로드된 어셈블리를 반환합니다.If an assembly with the same identity is already loaded, LoadFrom returns the loaded assembly even if a different path was specified.

  • 어셈블리를 사용 하 여 로드 LoadFrom, 로드 컨텍스트에 어셈블리 표시 이름으로 동일한 어셈블리를 로드 하려고 시도 하는 나중에 로드 하려고 하면 실패 합니다.If an assembly is loaded with LoadFrom, and later an assembly in the load context attempts to load the same assembly by display name, the load attempt fails. 어셈블리가 deserialize되면 이 문제가 발생할 수 있습니다.This can occur when an assembly is deserialized.

  • 어셈블리를 사용 하 여 로드 LoadFrom, id가 같지만 다른 위치를 사용 하 여 어셈블리 검색 경로 포함 되어는 InvalidCastException, MissingMethodException, 또는 기타 예기치 않은 동작이 발생할 수 있습니다.If an assembly is loaded with LoadFrom, and the probing path includes an assembly with the same identity but a different location, an InvalidCastException, MissingMethodException, or other unexpected behavior can occur.

  • LoadFrom은 지정된 경로에서 FileIOPermissionAccess.ReadFileIOPermissionAccess.PathDiscovery 또는 WebPermission을 요구합니다.LoadFrom demands FileIOPermissionAccess.Read and FileIOPermissionAccess.PathDiscovery, or WebPermission, on the specified path.

  • 네이티브 이미지에 대 한 있으면 assemblyFile, 사용 되지 않습니다.If a native image exists for assemblyFile, it is not used. 어셈블리가는 도메인 중립적으로 로드할 수 없습니다.The assembly cannot be loaded as domain neutral.

  • .NET Framework 버전 1.0 및 1.1에서는 정책이 적용 되지 않습니다.In the .NET Framework version 1.0 and 1.1, policy is not applied.

어셈블리에 대한 특정 권한 부여 여부는 증명 정보를 바탕으로 합니다.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:

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

  • 사용 하는 경우는 LoadFrom 메서드는 Evidence 매개 변수를 증거의 조각을 병합 됩니다.When you use a LoadFrom method with an Evidence parameter, pieces of evidence are merged. 인수로 제공 하는 증거의 조각을 LoadFrom 메서드는 로더에 의해 제공 된 증명 정보를 대체 합니다.Pieces of evidence supplied as an argument to the LoadFrom method supersede pieces of evidence supplied by the loader.

  • 한 번에이 메서드를 호출 하면 동일한 어셈블리에 있지만 지정 된 다른 증명, 공용 언어 런타임에서 throw 하지 않습니다는 FileLoadException 같음 및 다른 증명 사양의 무결성을 확인할 수 없으므로 합니다.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.

  • 사용 하는 경우는 LoadFrom 메서드는 Byte[] 공용 개체 파일 (COFF) 형식 이미지를 증명 정보를 로드 하려면 매개 변수 결합 됩니다.When you use a LoadFrom method with a Byte[] parameter to load a common object file format (COFF) image, evidence is combined. ZoneUrl 하 고 Site 호출 하는 어셈블리에서 상속 됩니다 및 HashStrongName COFF 어셈블리에서 수행 됩니다.Zone, Url and Site are inherited from the calling assembly, and Hash and StrongName are taken from the COFF assembly.

  • 사용 하는 경우는 LoadFrom 메서드를 Byte[] 매개 변수 및 Evidence COFF 이미지를 로드 하려면 제공 된 증명 정보를 사용 합니다.When you use a LoadFrom 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.

보안

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

FileIOPermission
"file://"로 시작 하는 URI를 읽는 합니다.for reading a URI that begins with "file://". 연결 된 열거형: ReadAssociated enumeration: Read

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

추가 정보

적용 대상