jspf插件框架

 

简介: java

jspf (Java Simple Plugin Framework) 是一个插件框架,用于减小小型项目的的开发时间,增长代码的可维护性。他彻底隐藏了组件的详细实现,只用到他们的接口。加载组件所须要的代码也不多,便于编写。 缓存

jspf框架彻底基于java注释实现 安全

@PluginImplementation,@InjectPlugin,@PluginLoaded,@Timer 网络

和@Thread等. 框架

(关于java注释:元数据从metadata一词译来,就是“关于数据的数据”的意思。愈来愈的开源框架都提供了“元数据”支持,其实也就是注释支持。Annotation是从java5开始在语言级别提供的一项新特性,Annotation提供了一条与程 jsp

序元素关联任何信息或者任何元数据(metadata)的途径。从某些方面看,annotation就像修饰符同样被使用,并应用于包、类型、构造方法、方法、成员变量、参数、本地变量的声明中。这些信息被存储在annotation的“name=value”结构对中。annotation类型是一种接口,可以经过java反射API的方式提供对其信息的访问。) ide

支持:从JAR文件加载插件,从一个目录加载多个插件,自动加载classpath中全部的插件,经过HTTP加载插件。线程安全。类型安全。支持缓存。插件能够使用一个单独的ClassLoader进行能够分离 google

相应接口说明 url

PluginManager pm=PluginManagerFactory.createPluginManager(); spa

pm.addPluginsFrom(new File("myPluginDir/").toURI());

/*PluginManagerFactory类是为了建立一个新的插件管理中心,这是使用jspf的入口和开始点。*/

public void addPluginsFrom(URI url, AddPluginsFromOption... options);

(@param1 url就是指加载插件的路径

  @param2 忽略不使用)

/*插件管理器从指定路径加载一个插件,这个路径能够是文件夹下的zip文件,jar文件,也能够是类文件。插件管理器将寻找含有@PluginImplementation 注释的类(classes),而且根据这个注释来初始化插件*/

addPluginsFrom(new URI("classpath://*"))

加载全部插件在当前的类路径

addPluginsFrom(new File("plugins/").toURI())

 加载全部指定路径内的插件

addPluginsFrom(new File("plugin.jar").toURI())

加载一个jar格式的插件

addPluginsFrom(new URI("http://sample.com/plugin.jar"))

从网络路径上下载而且加载插件

addPluginsFrom(new ClassURI(ServiceImpl.class).toURI())

直接加载一个插件实现的类文件

public <P extends Plugin> P getPlugin(Class<P> plugin, GetPluginOption... options);

(@param1 plugin就是指插件的类文件,如plugin1.class....

  @param2 忽略不使用)

如何使用:

经过http://code.google.com/p/jspf/downloads/list 

下载文件,在java工程中导入jspf.core-1.0.0.jar,仿照下面介绍的简单例子就能够实现一个简单的插件管理程序。

代码示例:利用jspf框架加载两个插件的实现

1. 建立一个java接口文件CoolPlugin,代码以下:

package coolplugin;

import net.xeoh.plugins.base.Plugin; 

public interface CoolPlugin extends Plugin

{

public String sayCool();

}

extends Plugin其中Plugin是jspf.core-1.0.0.jar中package net.xeoh.plugins.base中提供的public interface Plugin

建立一个java类文件,CoolPluginImpl,代码以下:

package impl;

import coolplugin.CoolPlugin;

import net.xeoh.plugins.base.annotations.PluginImplementation;

@PluginImplementation

public class CoolPluginImpl implements CoolPlugin

{

public String sayCool()

{

return "Hello!Cool!";

}

}

(上述插件接口的实现@PluginImplementation不可少

这样就完成了第一个Cool插件的编写

2. 建立一个java接口文件HotPlugin,代码以下:

package hotplugin;

import net.xeoh.plugins.base.Plugin; 

public interface HotPlugin extends Plugin

{

public String sayHot();

}

建立一个java类文件,HotPluginImpl,代码以下:

package impl;

import hotplugin.HotPlugin;

import net.xeoh.plugins.base.annotations.PluginImplementation;

@PluginImplementation

public class HotPluginImpl implements HotPlugin

{

public String sayHot()

{

return "Hello!Hot!";

}

}

这样就完成了第二个Hot插件的编写

3.编写插件管理中心main,代码以下

public static void main(String[] args) throws MalformedURLException

{

PluginManager pm = PluginManagerFactory.createPluginManager();

/*load classpath*/

pm.addPluginsFrom(new File("bin/").toURI());

CoolPlugin plugin1 = pm.getPlugin(CoolPlugin.class);

System.out.println(plugin1.sayCool());

HotPlugin plugin2 = pm.getPlugin(HotPlugin.class);

System.out.println(plugin2.sayHot());

}

运行后获得的结果是

"Hello!Cool!"

"Hello!Hot!"

利用"addPluginsFrom("...",new OptionReportAfter());"监视方法,能够得到详细信息:

Class Report <<<

    ****.CoolPluginImpl (status:'SPAWNED'; dependencies:''; origin:'file:*****;)

    ****.HotPluginImpl (status:'SPAWNED'; dependencies:''; origin:'file****/';)

>>> Object Report <<<

    ****.CoolPluginImpl @162db76 (status:'ACTIVE')

****.HotPluginImpl @21a14e (status:'ACTIVE')

说明两个插件加载成功

相关文章
相关标签/搜索