javaweb项目插件实现机制

如题,java开发web程序想实现插件机制有什么办法?

就比如:一个论坛,里面有签到,积分,第三方登录,编辑器选择等等的功能,现在我想把他们都抽出来,当成插件,论坛核心只保留用户的登录,注册,发帖,回复等最基本的功能,其他的功能都可以在后台点击安装,自动下载插件安装到服务器,然后就可以使用了

eclipse,idea等开发工具都是java写的,插件都是以jar包来安装的,然后重启重新加载插件
所以我也想让javaweb程序也能以jar包的形式来下载安装并使用

  1. 看过alibaba开源的druid,就是jar包形式安装,然后将页面部分(数据库操作的监控页面)也都打包到jar里,然后在spring的配置文件里配置访问路径,这样就可以在浏览器里输入地址查看监控信息了,但这样实现与核心部分毫不相干的功能是可行的,但与核心功能有交集的话,这个该怎么处理呢?

举个例子:签到功能,在论坛的首页的某处有一个按钮,用户点击了可以进行签到操作,代码部分还要是实现与用户个人信息相关的更新部分,这个该如何将一些与核心功能(页面)有交集的插件打包成jar,并能直接引入就使用呢?

  1. 有些插件涉及到了用户的个人信息部分,关于获取用户的信息或处理用户信心该怎么处理比较好呢?
  2. 后续核心部分版本升级,插件的兼容性处理方面应该怎么处理或在开发插件的时候应该注意些什么呢?

自己百度了下,javaweb实现插件方式开发的文章基本上没有(不知道是不是我搜索的姿势不对),如果有相关文章还望留个链接,不甚感激!

暂时想到这么多,跪求大神解答!!


这段时间折腾springboot找到了解决办法,详见博客 spring-boot 项目利用spring切面实现插件功能,对项目无侵入

回答:

discuz论坛的插件大概原理可以作为参考,说说我所知道的,有没有用楼主可以自己判断下

  1. 首先保证插件相关文件都存储在固定的插件目录下形成规范,这个可以解决你所提到的插件下载以及存储、部署等问题,至于插件打包的格式,这个楼主可以慢慢研究,zip,jar,war都可以,只要可以解压到对应的插件目录即可

  2. 可以针对插件进行一个分类,比如独立运行的插件、程序扩展插件、脚本等,然后针对性实现插件的机制,比如独立的运行的插件只要在某些地方进行链接插入即可,如果是程序扩展插件,那么可能需要统一插件调用函数或者其他机制

  3. 如果做的完善一些扩展性好一些,还可以要求或让插件继承一些你的类,方便插件编写

试着回答下楼主的1,2,3点问题:

  1. 插件调用有两种方式,1:预先分布到系统各个位置一些钩子运行的程序,指定插件可以在对应的地方调用 2:插件安装好以后修改基础程序调用钩子,这个和应用的运营方式有关,如果是开源的可能要实现复杂的插件调用逻辑,如果是内部用,可以简单一些,直接修改程序调用插件,这个可以考虑下实际情况

2.插件只能调用用户信息吧,如果真的让插件可以修改或者考虑安全性,那么可以考虑开发有一个插件权限审核功能,让插件开发的时候向系统发起的权限申请,然后系统来进行审核,或者系统主动派权限,貌似也和实际情况有关

3.系统升级插件不兼容的部分提示修改,插件升级的话直接更新下载覆盖插件目录

回答:

Java通过URLClassLoader让程序支持插件扩展:
http://xxgblog.com/2013/07/04/java-urlclassloader-plugin/

这是我很久以前写的一篇博客,通过定义插件接口加上反射加载插件jar包,实现和你所描述的需求非常相似,不知道能不能帮到你。

回答:

JAVA WEB插件开发一般使用OSGi技术,这方面JXADF开源、免费,做得相当优秀,详细参见:http://osgia.com/
1.png

以上是 javaweb项目插件实现机制 的全部内容, 来源链接: utcz.com/p/174379.html

回到顶部