关于软件中的插件类功能的一个实现

原创 2004年10月06日 02:32:00

商业化的软件大多支持功能扩展,比较普遍的方法就是使用插件,更实际的形式就是提供一个DLL或类似的文件,由商业软件在载入时自动检测这些DLL文件,来实现功能的扩展,在公司的某个产品开发中,我也使用了类似的技术,但我使用的方法并没有参考网上已有的代码,而是自己构思了一种方法,在原理上可能与此技术也相似。(我并没有真正的去研究那些插件实现的方法,呵呵,所以无法确认是否一致)

主要原理就是商业软件在载入内存运行时,会自动检测当前目录下的某个目录夹,例如Extra目录,枚举所有的DLL文件(如果为了保密,可将DLL后缀改为其它名称,甚至可将此文件进行加密,在内存中解密后再进行调用,但这不在本文讨论范围内),并根据预定义的函数名进行功能调用(注意:里面很重要的一点,就是所有的DLL文件提供的函数接口名都必须相同),我在此定义了2个函数接口,一是GetInfo函数,主要返回此扩展模块的版本号及一些相关信息,二是DoWork函数,也就是真正的需要被我们调用的工作函数,在此,我们可以设想到,我们完全可以由DoWork函数作为入口,在此函数体内实现我们所有需要的功能,例如画一个对话框,或其它一些我们想做的事,由此商业软件的功能将由这些扩展模块进行无限扩展。


术语重点:Win32 DLL编制接口规范/Win32 DLL调用规范
(具体规范要求,可以参考Windows深入编程类书籍)
   

开发工具:Visual C++ 6.0(SP5)

 

以下列出了我在相关实现中的部分代码:
---------------------------------------------------------
扩展模块函数定义模块:(DLL中被导出的2个函数定义,可被其它dll/exe文件调用)
Public:
BOOL GetInfo(char * Myinfo_data);    //返回DLL版本号及其它一些信息,结果将保存至Myinfo中,可将此char *强制转换成一自定义struct
LONG DoWork(char * name,int usenum,char * work_para);//实际工作函数


商业软件中调用DLL模块部分实现:
//检索所有的扩展DLL库
HINSTANCE hDLL;               // 函数DLL句柄
char* Myinfo_tmp;
MyInfo info;   //我自定义的一个struct的引用
Myinfo_tmp=(char*)malloc(sizeof(MyInfo));//分配内存

typedef bool (CALLBACK* LPFNDLLFUNC1)(char *); //回叫函数声明
LPFNDLLFUNC1 GetInfo;    // 函数指针
LPFNDLLFUNC1 DoWork;    // 函数指针

int pst=0;  //扩展DLL函数个数计数
CString path,filename,othermsg;
WIN32_FIND_DATA wfd; //MFC中的一个struct引用
path.Format("extra//*.dll");
HANDLE handle=FindFirstFile(path,&wfd);  //打开枚举句柄
//以下是枚举extra目录下所有后缀为dll的代码
if(handle!=INVALID_HANDLE_VALUE) 
{
 do
 {
  filename.Format("extra//%s",(CString)wfd.cFileName);
  hDLL = LoadLibrary(filename); //载入检索到的DLL文件到内存
  if (hDLL != NULL)
  {
   GetInfo = (LPFNDLLFUNC1)GetProcAddress(hDLL, "GetInfo"); //取得GetInfo函数在内存中的入口地址
   if(GetInfo)
   {
    GetInfo(Myinfo_tmp);
    memcpy(&info,Myinfo_tmp,sizeof(MyInfo));
    m_List.AddString(info.name); //将name加入list控件中
    othermsg.Format("厂商:%s/n/n文件名:%s/t版本号:%s/n/n其它信息:%s",info.name,info.DllName,info.ver,fwinfo.other);

    DoWork=(LPFNDLLFUNC2)GetProcAddress(hDLL,"DoWork");    //取得DoWork函数在内存中的入口地址

    if(!DoWork("name",3,"now"))         AfxMessageBox("调用DoWork函数时出错!");
   }
   pst++;
  }
 }
 FreeLibrary(hDLL); //释放句柄
}
while(FindNextFile(handle,&wfd));
 
FindClose(handle); //关闭枚举句柄
free(Myinfo_tmp); //释放内存

---------------------------------------------------------

以上是相关调用的实现代码,大家如有疑问,可发邮件于我,或在此留言,呵呵,可能会有更巧妙的方法实现扩展功能,希望我能抛砖引玉,引出更好的实现方法来。  

注:此文为原创,写于2001年,为在此blog上凑集文章,故又翻出张贴于此处,贻笑大方!

Android应用插件式开发解决方法

转自:http://blog.csdn.net/arui319/article/details/8109650 一、现实需求描述 一般的,一个Android应用在开发到了一定阶段以...
  • u014702999
  • u014702999
  • 2015年11月25日 11:43
  • 752

单一职责 -- 每个类只负责一个功能

单一职责原则是最简单的面向对象设计原则,它用于控制类的粒度大小。单一职责原则定义如下: 单一职责原则(Single Responsibility Principle, SRP):一个类只负责...
  • u013233468
  • u013233468
  • 2014年01月14日 09:54
  • 877

教你在APP中嵌入翻译功能,不借助第三方软件

对于翻译软件大家都应该使用过,有没有想到将翻译功能直接嵌入到自己的APP中,比如聊天界面,翻译几句话的功能。正好项目由此需求,看了看有道对外提供的接口,原来很简单。 一、效果图   说明...
  • qq_24531461
  • qq_24531461
  • 2017年06月01日 14:00
  • 902

基于Qt的画板程序编写

原理:   两点确定一条直线,通过确定鼠标点击点的x与y坐标值从而确定一条直线;而通过鼠标响应事件来确定鼠标的x与y轴值,并将鼠标的坐标存储与链表_list中,通过pen对象来设置线条的宽度,颜色等属...
  • u010445843
  • u010445843
  • 2015年01月04日 00:45
  • 1149

堆栈和队列的实现

要求:写Stack.java,实现堆栈功能,使用int数组保存数据 特点:先进后处 后进先出 Queue.java,实现队列功能,使用int数组保存数据 特点:先进先出 后进后出 使用Test....
  • suwu150
  • suwu150
  • 2016年08月09日 23:09
  • 970

一个简单的图片浏览器

Xml文件     xmlns:tools="http://schemas.android.com/tools"     android:layout_width="match_parent"...
  • mynameisIT
  • mynameisIT
  • 2014年10月13日 12:02
  • 167

如何对一个类进行扩展?

如何对一个类进行扩展? 在对类的处理中,我们会应用到的主要由四种方式, 一、    继承(inherit) 面向对象程序有三大特性,封装、继承、多态。    封装就是对一个类或者我们需要的一系...
  • V5V6_neil
  • V5V6_neil
  • 2014年07月06日 20:48
  • 744

基于java se中 JFrame,I/O流的完整记事本软件程序并拥有复制,粘贴,剪切功能。

该软件主要完成普通的记事本编辑功能。能够打开文件,保存文件新建文件等,这也是在浏览器中必要的功能,所以接上次浏览器的拆分,这里先介绍一下记事本程序的设计。 记事本程序是一个比较简单的基于java 流...
  • shuiyichuan
  • shuiyichuan
  • 2013年11月18日 14:58
  • 1568

c++ 插件技术的实现

应用程序中使用插件技术,有利于日后的版本更新、维护(比如打补丁)和功能扩展,是一种很实用的技术。其最大的特点是更新插件时无需重新编译主程序,对于一个设计良好的应用系统而言,甚至可以做到业务功能的在线升...
  • xiaohaizi77881314
  • xiaohaizi77881314
  • 2013年08月14日 01:01
  • 833

2013北邮java教程第4次实验Time类

1.完成Time类,要求该类能够实现以下功能: a.      该类以小时和分钟显示一天中的时间;提供两种计时功能,一种以24小时计时,一种以12小时计时;默认以24小时计时; b.      可...
  • Carp_and_wind
  • Carp_and_wind
  • 2013年04月10日 11:20
  • 1030
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:关于软件中的插件类功能的一个实现
举报原因:
原因补充:

(最多只允许输入30个字)