如何创建仅在插件可用时调用函数的插件机制?

时间:2013-02-17 21:30:21

标签: c# design-patterns architecture asp.net-mvc-4

对不起,如果我不够清楚,我很难写这个问题。

我下载了一个开源软件。我想扩展功能,所以我想创建封装这些模块将是.dll文件的功能的模块。 我希望有一个完全独立于另一个:如果我在配置文件中将密钥设置为true,并且如果该文件夹中存在DLL,则应该加载该插件。

问题是:如何动态调用插件(仅应用插件调用)?

如果我直接引用插件类,我将不得不引用插件dll,但我希望能够在没有插件的情况下运行核心软件。是否有任何设计模式或其他机制允许我仅在应用插件时加载和使用DLL,并且仍然可以在没有插件的情况下运行核心软件?

4 个答案:

答案 0 :(得分:3)

有多种方法可以实现这一点,我将在这里描述一个简单的解决方案。

创建一个通用接口,每个插件必须实现,以便与核心应用程序集成。这是一个例子:

// Interface which plugins must implement
public interface IPlugin
{
  void DoSomething(int Data);
}

// Custom plugin which implements interface
public class Plugin : IPlugin
{
  public void DoSomething(int Data)
  {
    // Do something
  }
}

要从dll实际加载插件,您需要使用反射,例如:

// Load plugin dll and create plugin instance
var a = Assembly.LoadFrom("MyCustomPlugin.dll");
var t = a.GetType("MyCustomPlugin.Plugin");
var p = (IPlugin)Activator.CreateInstance(t);

// Use plugin instance later
p.DoSomething(123);

您可以为插件程序集和类使用某种命名约定 这样你就可以轻松加载它们了。

答案 1 :(得分:2)

您可以使用MEF

  

托管扩展性框架(MEF)是一个组合层   .NET提高了灵活性,可维护性和可测试性   大型应用。 MEF可用于第三方插件   可扩展性,或者它可以带来松散耦合的好处   类似于插件的架构,适用于常规应用程序。

Here是编程指南。

答案 2 :(得分:2)

.NET术语中的插件或DLL称为程序集。查看Assembly.Load方法,以及this guide in msdn

答案 3 :(得分:1)

System.Reflection namespace提供了许多可以帮助您解决此问题的工具。

你可以

  • 检查程序集(DLL文件)以检查其中的对象,
  • 找到您要查找的类型(特定类,实现特定接口的类等)
  • 创建这些类的新实例,
  • 调用方法并访问这些类的属性。

通常,您会在扩展中编写一个类来完成某些工作,创建一个方法(例如DoWork()),然后动态调用该方法。

这个问题中提到的MEF就是这样做的,只是有了更多的框架。