Assembly.Load Assembly.Load Assembly.Load Assembly.Load Method

定義

アセンブリを読み込みます。Loads an assembly.

オーバーロード

Load(AssemblyName) Load(AssemblyName) Load(AssemblyName) Load(AssemblyName)

AssemblyName を指定してアセンブリを読み込みます。Loads an assembly given its AssemblyName.

Load(Byte[], Byte[], SecurityContextSource) Load(Byte[], Byte[], SecurityContextSource) 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) Load(Byte[], Byte[], Evidence) Load(Byte[], Byte[], Evidence) 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) Load(String, Evidence) Load(String, Evidence) Load(String, Evidence)

表示名を指定してアセンブリを読み込みます。アセンブリは、指定された証拠を使用して、呼び出し元のドメインに読み込まれます。Loads an assembly given its display name, loading the assembly into the domain of the caller using the supplied evidence.

Load(Byte[]) Load(Byte[]) Load(Byte[]) 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(Byte[], Byte[]) Load(Byte[], Byte[]) Load(Byte[], Byte[]) Load(Byte[], Byte[])

生成されたアセンブリが含まれている COFF (Common Object File Format) ベースのイメージを使用して、このアセンブリを読み込みます。アセンブリのシンボルを含めることもできます。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(String) Load(String) Load(String) Load(String)

長い形式の名前を指定してアセンブリを読み込みます。Loads an assembly given the long form of its name.

Load(AssemblyName, Evidence) Load(AssemblyName, Evidence) Load(AssemblyName, 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(AssemblyName) Load(AssemblyName) Load(AssemblyName) 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 AssemblyName AssemblyName 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 を代わりにキャッチします。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. アセンブリのパブリック型の完全名を表示します。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

注釈

FileLoadException 場合にスローされるassemblyRefアセンブリの完全な名前と簡単な名前に一致する最初のアセンブリが別のバージョン、カルチャ、または公開キー トークンを指定します。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 以降、FileLoadException場合にスローされるもassemblyRefリモート アセンブリを指定します。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.

注意

使用しないでください、AssemblyNameだけを持つ、CodeBaseプロパティ セット。Do not use an AssemblyName with only the CodeBase property set. CodeBaseプロパティがいずれかの要素を指定しないアセンブリの id (名前、バージョンなど) のための読み込みは発生しません - id によって負荷の規則に従ってから想像どおり、Loadメソッド。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:

  • 使用すると、LoadなしでメソッドEvidenceパラメーター、アセンブリの表示はローダーが提供する証拠を使用して読み込まれます。When you use a Load method with no Evidence parameter, the assembly is loaded with the evidence that the loader supplies.

  • 使用すると、LoadメソッドをEvidenceパラメーターの証拠がマージされます。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.

  • 使用すると、Loadでメソッドのオーバー ロードをByte[]パラメーターは、common object file format (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 version 1.1 に当てはまります Service Pack 1 (SP1) と今後のリリース。This applies to the .NET Framework version 1.1 Service Pack 1 (SP1) and subsequent releases.

    注意

    .NET Framework version 1.0 と version 1.1 を使用するときに SP1 がない場合、Loadでメソッドのオーバー ロードをByte[]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. ZoneUrlSiteは呼び出し元のアセンブリから継承されるとHashStrongNameCOFF アセンブリから取得されます。Zone, Url and Site are inherited from the calling assembly, and Hash and StrongName are taken from the COFF assembly.

  • 使用すると、LoadメソッドをByte[]パラメーターとEvidenceCOFF イメージを読み込むには、指定された証拠のみが使用されます。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します。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. 保持するために、 .reloc C++ 実行可能ファイルのアドレスで指定/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がスローされます。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. 列挙体に関連付けられている: ReadPathDiscoveryAssociated 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[], SecurityContextSource) Load(Byte[], Byte[], SecurityContextSource) 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 SecurityContextSource 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 の値は、列挙値の 1 つではありません。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) Load(Byte[], Byte[], Evidence) Load(Byte[], Byte[], Evidence) 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 http://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 Evidence 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.

アセンブリまたはモジュールが、2 つの異なる証拠を使用して 2 回読み込まれました。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:

  • 使用すると、LoadなしでメソッドEvidenceパラメーター、アセンブリの表示はローダーが提供する証拠を使用して読み込まれます。When you use a Load method with no Evidence parameter, the assembly is loaded with the evidence that the loader supplies.

  • 使用すると、LoadメソッドをEvidenceパラメーターの証拠がマージされます。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.

  • 使用すると、Loadでメソッドのオーバー ロードをByte[]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 version 1.1 に当てはまります Service Pack 1 (SP1) と今後のリリース。This applies to the .NET Framework version 1.1 Service Pack 1 (SP1) and subsequent releases.

    注意

    .NET Framework version 1.0 と version 1.1 を使用するときに SP1 がない場合、Loadでメソッドのオーバー ロードをByte[]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. ZoneUrlSiteは呼び出し元のアセンブリから継承されるとHashStrongNameCOFF アセンブリから取得されます。Zone, Url and Site are inherited from the calling assembly, and Hash and StrongName are taken from the COFF assembly.

  • 使用すると、LoadメソッドをByte[]パラメーターとEvidenceCOFF イメージを読み込むには、指定された証拠のみが使用されます。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します。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. 保持するために、 .reloc C++ 実行可能ファイルのアドレスで指定/fixed:noリンクしています。To preserve the .reloc address for your C++ executable file, specify /fixed:no when you are linking.

呼び出す場合、[]、バイト<xref:System.Reflection.Assembly.Load%2A > メソッドを 1 回、同じアセンブリでは、さまざまな証拠を指定、共通言語ランタイムをスローしないより、FileLoadExceptionのため、等しいかどうかと、さまざまな証拠の仕様の整合性を特定できません。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. ControlEvidence (関連する列挙体)Associated enumeration: ControlEvidence. セキュリティ アクション:Demandします。Security action: Demand.

Load(String, Evidence) Load(String, Evidence) Load(String, Evidence) 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 http://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 String String String

アセンブリの表示名。The display name of the assembly.

assemblySecurity
Evidence Evidence Evidence 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- アセンブリまたはモジュールが、2 つの異なる証拠を使用して 2 回読み込まれました。An assembly or module was loaded twice with two different evidences.

注釈

FileLoadException 場合にスローされるassemblyString完全なアセンブリ名と簡易名に一致する最初のアセンブリが別のバージョン、カルチャ、または公開キー トークンを指定します。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:

  • 使用すると、LoadなしでメソッドEvidenceパラメーター、アセンブリの表示はローダーが提供する証拠を使用して読み込まれます。When you use a Load method with no Evidence parameter, the assembly is loaded with the evidence that the loader supplies.

  • 使用すると、LoadメソッドをEvidenceパラメーターの証拠がマージされます。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.

  • 使用すると、Loadでメソッドのオーバー ロードをByte[]パラメーターは、common object file format (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 version 1.1 に当てはまります Service Pack 1 (SP1) と今後のリリース。This applies to the .NET Framework version 1.1 Service Pack 1 (SP1) and subsequent releases.

    注意

    .NET Framework version 1.0 と version 1.1 を使用するときに SP1 がない場合、Loadでメソッドのオーバー ロードをByte[]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. ZoneUrlSiteは呼び出し元のアセンブリから継承されるとHashStrongNameCOFF アセンブリから取得されます。Zone, Url and Site are inherited from the calling assembly, and Hash and StrongName are taken from the COFF assembly.

  • 使用すると、LoadメソッドをByte[]パラメーターとEvidenceCOFF イメージを読み込むには、指定された証拠のみが使用されます。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します。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. 保持するために、 .reloc C++ 実行可能ファイルのアドレスで指定/fixed:noリンクしています。To preserve the .reloc address for your C++ executable file, specify /fixed:no when you are linking.

共通言語ランタイムがスローしない場合は、同じアセンブリが異なる証拠を指定に、このメソッドを複数回呼び出す、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.

.NET Framework version 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.ProcessorArchitectureSee AssemblyName.ProcessorArchitecture.

セキュリティ

SecurityPermission
証拠とアセンブリの読み込み。to load an assembly with evidence. 関連付けられた列挙体。 ControlEvidenceAssociated enumeration: ControlEvidence

こちらもご覧ください

Load(Byte[]) Load(Byte[]) Load(Byte[]) 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します。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. 保持するために、 .reloc C++ 実行可能ファイルのアドレスで指定/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(Byte[], Byte[]) Load(Byte[], Byte[]) Load(Byte[], Byte[]) Load(Byte[], Byte[])

生成されたアセンブリが含まれている COFF (Common Object File Format) ベースのイメージを使用して、このアセンブリを読み込みます。アセンブリのシンボルを含めることもできます。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します。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. 保持するために、 .reloc C++ 実行可能ファイルのアドレスで指定/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) Load(String) Load(String) Load(String)

長い形式の名前を指定してアセンブリを読み込みます。Loads an assembly given the long form of its 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 String String String

長い形式のアセンブリ名。The long 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 this code example to run, you must provide the fully qualified assembly name. 完全修飾アセンブリ名を取得する方法については、次を参照してください。アセンブリ名します。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
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 'Class1

注釈

長い形式のアセンブリ名は、そのバージョン、カルチャ、公開キー トークン、および必要に応じてそのプロセッサ アーキテクチャと単純な名前 ("System"System.dll アセンブリの) などで構成されます。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.dll アセンブリの読み込みに長い名前の使用を示します。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

FileLoadException 場合にスローされるassemblyString完全なアセンブリ名と簡易名に一致する最初のアセンブリが別のバージョン、カルチャ、または公開キー トークンを指定します。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:

  • 使用すると、LoadなしでメソッドEvidenceパラメーター、アセンブリの表示はローダーが提供する証拠を使用して読み込まれます。When you use a Load method with no Evidence parameter, the assembly is loaded with the evidence that the loader supplies.

  • 使用すると、LoadメソッドをEvidenceパラメーターの証拠がマージされます。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.

  • 使用すると、Loadでメソッドのオーバー ロードをByte[]パラメーターは、common object file format (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 version 1.1 に当てはまります Service Pack 1 (SP1) と今後のリリース。This applies to the .NET Framework version 1.1 Service Pack 1 (SP1) and subsequent releases.

    注意

    .NET Framework version 1.0 と version 1.1 を使用するときに SP1 がない場合、Loadでメソッドのオーバー ロードをByte[]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. ZoneUrlSiteは呼び出し元のアセンブリから継承されるとHashStrongNameCOFF アセンブリから取得されます。Zone, Url and Site are inherited from the calling assembly, and Hash and StrongName are taken from the COFF assembly.

  • 使用すると、LoadメソッドをByte[]パラメーターとEvidenceCOFF イメージを読み込むには、指定された証拠のみが使用されます。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します。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. 保持するために、 .reloc C++ 実行可能ファイルのアドレスで指定/fixed:noリンクしています。To preserve the .reloc address for your C++ executable file, specify /fixed:no when you are linking.

.NET Framework version 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.ProcessorArchitectureSee AssemblyName.ProcessorArchitecture.

セキュリティ

SecurityPermission
証拠とアセンブリの読み込み。to load an assembly with evidence. 関連付けられた列挙体。 ControlEvidenceAssociated enumeration: ControlEvidence

こちらもご覧ください

Load(AssemblyName, Evidence) Load(AssemblyName, Evidence) Load(AssemblyName, Evidence) 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 http://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 AssemblyName AssemblyName AssemblyName

読み込むアセンブリを記述するオブジェクト。The object that describes the assembly to be loaded.

assemblySecurity
Evidence Evidence Evidence 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.

アセンブリまたはモジュールが、2 つの異なる証拠を使用して 2 回読み込まれました。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>.

注釈

FileLoadException 場合にスローされるassemblyRef完全なアセンブリ名と簡易名に一致する最初のアセンブリが別のバージョン、カルチャ、または公開キー トークンを指定します。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 以降、FileLoadException場合にスローされるもassemblyRefリモート アセンブリを指定します。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.

注意

使用しないでください、AssemblyNameだけを持つ、CodeBaseプロパティ セット。Do not use an AssemblyName with only the CodeBase property set. CodeBaseプロパティがいずれかの要素を指定しないアセンブリの id (名前、バージョンなど) のための読み込みは発生しません - id によって負荷の規則に従ってから想像どおり、Loadメソッド。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:

  • 使用すると、LoadなしでメソッドEvidenceパラメーター、アセンブリの表示はローダーが提供する証拠を使用して読み込まれます。When you use a Load method with no Evidence parameter, the assembly is loaded with the evidence that the loader supplies.

  • 使用すると、LoadメソッドをEvidenceパラメーターの証拠がマージされます。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.

  • 使用すると、Loadでメソッドのオーバー ロードをByte[]パラメーターは、common object file format (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 version 1.1 に当てはまります Service Pack 1 (SP1) と今後のリリース。This applies to the .NET Framework version 1.1 Service Pack 1 (SP1) and subsequent releases.

    注意

    .NET Framework version 1.0 と version 1.1 を使用するときに SP1 がない場合、Loadでメソッドのオーバー ロードをByte[]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. ZoneUrlSiteは呼び出し元のアセンブリから継承されるとHashStrongNameCOFF アセンブリから取得されます。Zone, Url and Site are inherited from the calling assembly, and Hash and StrongName are taken from the COFF assembly.

  • 使用すると、LoadメソッドをByte[]パラメーターとEvidenceCOFF イメージを読み込むには、指定された証拠のみが使用されます。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します。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. 保持するために、 .reloc C++ 実行可能ファイルのアドレスで指定/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がスローされます。If the match fails, a FileLoadException is thrown.

呼び出す場合、Loadメソッドの 1 回、同じアセンブリでは、さまざまな証拠を指定、共通言語ランタイムをスローしないより、FileLoadException等しいかどうかと、さまざまな証拠の仕様の整合性をすることはできませんので、決定されます。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. 列挙体に関連付けられている: ReadPathDiscoveryAssociated 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

こちらもご覧ください

適用対象