System.AppDomain.DefineDynamicAssembly 方法 (AssemblyName, AssemblyBuilderAccess, String, Evidence, PermissionSet, PermissionSet, PermissionSet, Boolean)

方法描述

使用指定名称、访问模式、存储目录、证据、权限请求和同步选项定义动态程序集。

语法定义(C# System.AppDomain.DefineDynamicAssembly 方法 (AssemblyName, AssemblyBuilderAccess, String, Evidence, PermissionSet, PermissionSet, PermissionSet, Boolean) 的用法)

[ObsoleteAttribute("Assembly level declarative security is obsolete and is no longer enforced by the CLR by default. See http://go.microsoft.com/fwlink/?LinkID=155570 for more information.")]
public AssemblyBuilder DefineDynamicAssembly(
	AssemblyName name,
	AssemblyBuilderAccess access,
	string dir,
	Evidence evidence,
	PermissionSet requiredPermissions,
	PermissionSet optionalPermissions,
	PermissionSet refusedPermissions,
	bool isSynchronized
)

参数/返回值

参数值/返回值 参数类型/返回类型 参数描述/返回描述
name System-Reflection-AssemblyName 动态程序集的唯一标识。
access System-Reflection-Emit-AssemblyBuilderAccess 访问动态程序集所采用的模式。
dir System-String 保存动态程序集的目录的名称。如果 dir 是 null,目录将默认为当前目录。
evidence System-Security-Policy-Evidence 为动态程序集提供的证据。该证据始终作为最后一组用于策略解析的证据来使用。
requiredPermissions System-Security-PermissionSet 必需的权限请求。
optionalPermissions System-Security-PermissionSet 可选权限请求。
refusedPermissions System-Security-PermissionSet 被拒绝的权限请求。
isSynchronized System-Boolean 若要在动态程序集中同步模块、类型和成员的创建,则为 true;否则为 false。
返回值 System.Reflection.Emit.AssemblyBuilder 具有指定名称和功能的动态程序集。

提示和注释

仅当还提供了 evidence,或者动态程序集被保存并且重新加载到内存中时,才使用为 requiredPermissions、optionalPermissions 和 refusedPermissions 指定的权限请求。

注意

在开发用于发出动态程序集的代码过程中,建议您在 refusedPermissions 中包括 SecurityPermissionFlag.SkipVerification。 在 refusedPermissions 参数中包括 SkipVerification 可以确保验证 MSIL。 这个技术的局限性在于,当与要求完全信任的代码一起使用时,它会导致引发 SecurityException。

只有完全受信任的调用方可以在定义动态 Assembly 时提供其 evidence。 运行时将通过安全策略映射 Evidence 来确定授予的权限。 部分受信任的调用方必须为 evidence 形参提供 null。 如果 evidence 是 null,运行时将权限集(即,当前授予集和拒绝集)从调用方的 Assembly 复制到正在定义的动态 Assembly,并将策略标记为已解析。

如果将动态 Assembly 保存到磁盘上,后面的加载将基于与保存 Assembly 的位置关联的策略获取授权。

如果 isSynchronized 为 true,则将同步所得 AssemblyBuilder 的下列方法:DefineDynamicModule、DefineResource、AddResourceFile、GetDynamicModule、SetEntryPoint 和 Save。 如果这些方法中的两个在不同线程上调用,则一个方法完成前另一个方法将一直阻止。

注意

在 .NET Framework 1.0、1.1 和 2.0 版中,通过使用 requiredPermissions、optionalPermissions 和 refusedPermissions 参数应用于动态程序集的声明性安全特性以旧的 XML 元数据格式存储。 请参见发出声明性安全特性。

System.AppDomain.DefineDynamicAssembly 方法 (AssemblyName, AssemblyBuilderAccess, String, Evidence, PermissionSet, PermissionSet, PermissionSet, Boolean)例子

有关如何获取完全限定程序集名称的信息,请参见程序集名称。

using System;
using System.Reflection;
using System.Reflection.Emit;

class Test {
   public static void Main() {
      AppDomain currentDomain = AppDomain.CurrentDomain;

      InstantiateMyDynamicType(currentDomain);   // Failed!

      currentDomain.AssemblyResolve += new ResolveEventHandler(MyResolveEventHandler);

      InstantiateMyDynamicType(currentDomain);   // OK!
   }

   static void InstantiateMyDynamicType(AppDomain domain) {
      try {
         // You must supply a valid fully qualified assembly name here. 
         domain.CreateInstance("Assembly text name, Version, Culture, PublicKeyToken", "MyDynamicType");
      } catch (Exception e) {
         Console.WriteLine(e.Message);
      }
   }   

   static Assembly MyResolveEventHandler(object sender, ResolveEventArgs args) {
      return DefineDynamicAssembly((AppDomain) sender);
   }

   static Assembly DefineDynamicAssembly(AppDomain domain) {
      // Build a dynamic assembly using Reflection Emit API.

      AssemblyName assemblyName = new AssemblyName();
      assemblyName.Name = "MyDynamicAssembly";

      AssemblyBuilder assemblyBuilder = domain.DefineDynamicAssembly(assemblyName, AssemblyBuilderAccess.Run);
      ModuleBuilder moduleBuilder = assemblyBuilder.DefineDynamicModule("MyDynamicModule");
      TypeBuilder typeBuilder = moduleBuilder.DefineType("MyDynamicType", TypeAttributes.Public);
      ConstructorBuilder constructorBuilder = typeBuilder.DefineConstructor(MethodAttributes.Public, CallingConventions.Standard, null);
      ILGenerator ilGenerator = constructorBuilder.GetILGenerator();

      ilGenerator.EmitWriteLine("MyDynamicType instantiated!");
      ilGenerator.Emit(OpCodes.Ret);

      typeBuilder.CreateType();

      return assemblyBuilder;
   }
}

异常

异常 异常描述
ArgumentNullException name 为 null。
ArgumentException
  • name 的 Name 属性为 null。
  • name 的 Name 属性以空白开始,或包含正斜杠或反斜杠。
AppDomainUnloadedException 尝试对已卸载的应用程序域进行操作。

命名空间

namespace: System

程序集: mscorlib(在 mscorlib.dll 中)

版本信息

.NET Framework 受以下版本支持:3.5、3.0、2.0、1.1、1.0 在 4 中过时(编译器警告) .NET Framework Client Profile 受以下版本支持:3.5 SP1 在 4 中过时(编译器警告)

适用平台

Windows 7, Windows Vista SP1 或更高版本, Windows XP SP3, Windows XP SP2 x64 Edition, Windows Server 2008(不支持服务器核心), Windows Server 2008 R2(支持 SP1 或更高版本的服务器核心), Windows Server 2003 SP2 .NET Framework 并不是对每个平台的所有版本都提供支持。有关支持的版本的列表,请参见.NET Framework 系统要求。