You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
|
|
|
# 帆软插件开发工具套件
|
|
|
|
|
|
|
|
## 作用简介
|
|
|
|
该套件在帆软工程类基础上做了二次封装,仅暴露接口,可以更好的兼容不同版本的非开放API。
|
|
|
|
|
|
|
|
比如,要获取报表的会话信息,以前需要调用方法
|
|
|
|
```java
|
|
|
|
import com.fr.web.core.SessionPoolManager;
|
|
|
|
import org.jetbrains.annotations.NotNull;
|
|
|
|
|
|
|
|
SessionPoolManager#getSessionIDInfor(@NotNull String sessionID, Class<T> clazz);
|
|
|
|
```
|
|
|
|
但可能随着版本的变更,SessionPoolManager变更了一个名字,比如由SessionPoolManager改成了NewSessionPoolManager,
|
|
|
|
那么所有调用了该API的插件都无法使用,必须要重新修改插件中的该处代码并更新插件才行。
|
|
|
|
|
|
|
|
而如果采用可开发工具套件中的方法,则始终都是调用
|
|
|
|
```java
|
|
|
|
import com.fanruan.api.session.SessionKit;
|
|
|
|
import org.jetbrains.annotations.NotNull;
|
|
|
|
|
|
|
|
SessionKit#getSession(@NotNull String sessionID);
|
|
|
|
```
|
|
|
|
仅仅只需要更新最新版本的开发套件工具包即可让老插件自然适配。
|
|
|
|
|
|
|
|
## 提交新API要求
|
|
|
|
|
|
|
|
* 所有的API方法的返回值和参数,仅允许使用基本类型、接口类型或者使用了@Open标记的对象类型。
|
|
|
|
|
|
|
|
* 所有的API方法均需要有单元测试覆盖。
|
|
|
|
|
|
|
|
* 所有的API方法均需要有javadoc文档说明。
|
|
|
|
|
|
|
|
## 使用方法
|
|
|
|
|
|
|
|
先使用maven打包,执行下面的命令(跳过单元测试)
|
|
|
|
|
|
|
|
```
|
|
|
|
mvn package -Dmaven.test.skip=true
|
|
|
|
```
|
|
|
|
|
|
|
|
会在target目录下获得一个形如finekit-10.0-20190815.jar名字jar包,直接作为插件依赖jar包即可。
|
|
|
|
|
|
|
|
## 已完全依赖FineKit的插件
|
|
|
|
|
|
|
|
|插件名|源码|
|
|
|
|
|-----|----|
|
|
|
|
|redis数据集插件|https://git.fanruan.com/fanruan/demo-tabledata-redis|
|