public static Type ToType(XmlSerializableType xmlSerializableType) { string func = "XmlSerialzationType.ToType"; Type type = null; if (xmlSerializableType != null && xmlSerializableType.Name != string.Empty) { type = Type.GetType(xmlSerializableType.Name); if (type == null) { // May be a user defined class try { Assembly assembly = Assembly.Load(xmlSerializableType.AssemblyName); type = assembly.GetType(xmlSerializableType.Name); } catch (Exception ex) { TestDebug.DebugTraceSevere(func,"Exception " + ex.ToString()); } } } return type; }
我有一个名为“leaf”的基类和一个名为“roundedtree”的用户定义类
当’xmlSerializableType.Name’成为用户定义的类’_rounded_tree’时,我第一次获得’assembly as _rounded_treeGOLD,Version = 0.0.0.0,Culture = neutral,PublicKeyToken = null’的值,因此’type as {Name =“_rounded_tree “FullName =”_ ground_tree“}’.但保存后,如果我重新启动我的应用程序,我无法加载“程序集”获取异常’无法加载文件或程序集’_rounded_treeGOLD,PublicKeyToken = null’或其依赖项之一的值.系统找不到指定的文件.“:”_ rounded_treeGOLD,PublicKeyToken = null’并且返回类型变为null这不应该发生
对于基类“leaf”没有发布,我将获得xmlSerializableType.Name作为“Root.Systemmodel.leaf”并且’type’变为{Name =“leaf”FullName =“Root.Systemmodel.leaf”}程序集将是Root.Systemmodel,Version = 8.0.7.0,PublicKeyToken = 83bd062a94e26d58
在这种情况下我该怎么办
这是一些代码,它将为用户定义的类生成程序集
public Type CreateType() { string func = "ManagedClass.CreateType"; // Create instances of AssemblyBuilder and ModuleBuilder for the new Type AppDomain myDomain = Thread.GetDomain(); AssemblyName myAsmName = new AssemblyName(); // Create the assembly name by appending the machine name to the typename. myAsmName.Name = this.TypeName + Environment.MachineName; // Define assembly that can be executed but not saved this.UserClassAssemblyBuilder = myDomain.DefineDynamicAssembly(myAsmName,AssemblyBuilderAccess.Run); // Create dynamic module with symbol information this.UserClassModuleBuilder = this.UserClassAssemblyBuilder.DefineDynamicModule("userdefinedmodule",true);
UPDATE
可能我的程序集是为用户定义的类创建但不保存可能是我第一次没有遇到任何问题的原因,一旦我关闭应用程序我会失去那个看到我的代码
// Define assembly that can be executed but not saved this.UserClassAssemblyBuilder = myDomain.DefineDynamicAssembly(myAsmName,
AssemblyBuilderAccess.Run);
如何克服这种情况
UPDATE
这里我的数据库是xml文件.当我检查基类叶时,我可以看到条目是< Name> Root.Systemmodel.WindowsSystem< / Name>< AssemblyName> Root.Systemmodel,PublicKeyToken = 83bd062a94e26d58< / AssemblyName> ;在这种情况下,如果重启我的应用程序没有问题,但对于用户定义的类“roundedtree”xml条目是< Name> _rounded_tree< / Name> < AssemblyName> _rounded_treeGOLD,PublicKeyToken = null< / AssemblyName>
这里第一次没有问题,但如果我重新启动我的应用程序我会得到例外
解决方法
我,我只是复制粘贴我的代码,但它清楚
private string asmBase; public Type[] GetAllTypeinAssembly(string assemblyName) { asmBase = System.IO.Path.GetDirectoryName(assemblyName); AppDomain.CurrentDomain.AssemblyResolve += new ResolveEventHandler(CurrentDomain_AssemblyResolve); System.Reflection.Assembly asm = System.Reflection.Assembly.Load(System.IO.File.ReadAllBytes(assemblyName));//domain.Load(bt) ;// return asm.GetTypes(); } private Assembly CurrentDomain_AssemblyResolve(object sender,ResolveEventArgs args) { //This handler is called only when the common language runtime tries to bind to the assembly and fails. //Retrieve the list of referenced assemblies in an array of AssemblyName. Assembly MyAssembly,objExecutingAssemblies; string strTempAssmbPath = ""; objExecutingAssemblies = args.RequestingAssembly; AssemblyName[] arrReferencedAssmbNames = objExecutingAssemblies.GetReferencedAssemblies(); //Loop through the array of referenced assembly names. foreach (AssemblyName strAssmbName in arrReferencedAssmbNames) { //Check for the assembly names that have raised the "AssemblyResolve" event. if (strAssmbName.FullName.Substring(0,strAssmbName.FullName.IndexOf(",")) == args.Name.Substring(0,args.Name.IndexOf(","))) { //Build the path of the assembly from where it has to be loaded. strTempAssmbPath = asmBase + "\\" + args.Name.Substring(0,")) + ".dll"; break; } } //Load the assembly from the specified path. MyAssembly = Assembly.LoadFrom(strTempAssmbPath); //Return the loaded assembly. return MyAssembly; }
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。