在应用程序之间传递动态程序集

简介: 所谓动态程序集,就是在运行期间由Emit创建的程序集。      假设,我们的Client和Server之间通过Remoting通信,在某个时刻,Client会创建一个动态程序集,并且Client和Server都会基于该程序集做一些动作,那么如何将动态程序集传递到Server端了?Client和Server如何正常使用这个程序集了?      我的经验是这样的:(1)Client端Emit动态程序集(Dynamic Assembly)完成后,将Dynamic Assembly保持到一个字典中,并再将其保存到一个本地的临时文件。

      所谓动态程序集,就是在运行期间由Emit创建的程序集。
      假设,我们的Client和Server之间通过Remoting通信,在某个时刻,Client会创建一个动态程序集,并且Client和Server都会基于该程序集做一些动作,那么如何将动态程序集传递到Server端了?Client和Server如何正常使用这个程序集了?

      我的经验是这样的:
(1)Client端Emit动态程序集(Dynamic Assembly)完成后,将Dynamic Assembly保持到一个字典中,并再将其保存到一个本地的临时文件。

private   IDictionary < string Assembly >  assemblyDictionary  =   new   Dictionary < string Assembly > ();  //Client 保持动态程序集
AssemblyBuilder  dynamicAssembly;
//
this .assemblyDictionary.Add(entityType.Assembly.FullName, entityType.Assembly);            
dynamicAssembly.Save(
" temp.dll " );


(2)将temp.dll文件读入到内存的buffer中,然后就可以删除临时文件了。

byte [] asmBuff  =   FileHelper .ReadFileReturnBytes( " temp.dll " );
FileHelper .DeleteFile( " temp.dll " );


(3)将asmBuff传递到Server端,Server端则可以从byte[]加载程序集,并将加载的程序集保持到一个字典中:

private   IDictionary < string Assembly >  assemblyDictionary  =   new   Dictionary < string Assembly > ();  //Server 保持动态程序集
//
Assembly  asm  =   AppDomain .CurrentDomain.Load(assBuff);
assemblyDictionary.Add(asm.FullName, asm);


(4)如此一来,Client和Server都保持了Dynamic Assembly的引用,但是,这还不够,在后续使用动态程序集的时候,会抛出类似“未能加载...程序集”的异常。所以,我们在Client和Server端都要通过预定AppDomain.CurrentDomain.AssemblyResolve事件来处理动态程序集加载失败的情况:

         AppDomain .CurrentDomain.AssemblyResolve  +=   new  ResolveEventHandler(CurrentDomain_AssemblyResolve);  // 处理动态程序集加载失败的情况  

         
Assembly  CurrentDomain_AssemblyResolve( object  sender,  ResolveEventArgs  args)
        {
            
if  ( this .assemblyDictionary.ContainsKey(args.Name))
            {
                
return   this .assemblyDictionary[args.Name];
            }
            
return   null ;
        } 


      再做完上述这些步骤之后,我们就可以在Client和Server端都正常的使用动态程序集了。

目录
相关文章
|
6月前
|
编译器 C# 开发者
C# 10.0中的全局`using`指令:简化命名空间引用的新方式
【1月更文挑战第4天】本文介绍了C# 10.0中引入的全局`using`指令,该指令允许开发者在项目级别统一管理命名空间引用,从而消除源文件中重复的`using`语句。全局`using`指令通过减少冗余代码、提高可维护性和统一命名空间管理,为开发者带来了更高效的编码体验。文章详细解释了如何实现全局`using`指令,并探讨了其在实际项目中的优势和适用场景。
|
2月前
|
缓存 Java 数据库连接
扩展类的附加特性
扩展类的附加特性
18 0
|
3月前
|
Java 数据库连接 数据库
|
4月前
|
开发框架 前端开发 JavaScript
在各种开发项目中使用公用类库的扩展方法,通过上下文方式快速调用处理函数
在各种开发项目中使用公用类库的扩展方法,通过上下文方式快速调用处理函数
|
安全
RxSwift特征序列Driver的使用,以及共享附加作用与非共享附加作用的区别?
RxSwift特征序列Driver的使用,以及共享附加作用与非共享附加作用的区别?
169 0
|
存储 Go
第三十章 使用系统监视器 - 编写用户定义的应用程序监视器类
第三十章 使用系统监视器 - 编写用户定义的应用程序监视器类
105 0
|
安全 C++ Windows
C++调用外部应用程序的方法的整理总结(常用)
一、三个SDK函数:  WinExec,ShellExecute ,CreateProcess可以实现调用其他程序的要求,其中以WinExec最为简单,ShellExecute比WinExec灵活一些,CreateProcess最为复杂。
3008 0
|
缓存
读源码长知识 | 动态扩展类并绑定生命周期的新方式
在阅读viewModelScope源码时,发现了一种新的方式。 协程需隶属于某 CoroutineScope ,以实现structured-concurrency,而 CoroutineScope 应
172 0
如何远程比较两个系统里同一个ABAP类方法代码的差异
如何远程比较两个系统里同一个ABAP类方法代码的差异
278 0
如何远程比较两个系统里同一个ABAP类方法代码的差异
|
C#
“在引用COM组件时,出现了无法嵌入互操作类型。。。”的错误
  这两天在做一个需要将wps文档转换成word文档的程序,在调用wps的com组件时项目编译是没有问题的,但当运行的时候却弹出了下面的错误提示: 从网上百度一番后,找到了正确的解决方法。    先从Com组件中添加引用:   选中引入的Com组件库,右键-> 属性:   将“嵌入互操作类型”改为 False 选项:   重新编译,程序正常运行。
1139 0