注:本文是基于托管服务TuoCloudService1.0.0讲解的 项目地址为
一,插件托管服务支持的功能
v1.0.0支持的功能如下:
注:它们都是以OSGI服务对外提供服务的,关于OSGI可百度查询,但同时我们提供模板代码,我们希望大家可以利用模板代码渐进式的学习 <apkplug中OSGI服务基本原理>
1.插件托管:
开发者可将宿主应用与插件上传到服务器上,并随意绑定宿主与插件的对应关系。
2.客户端多条件查询:
OSGI服务名:"com.apkplug.service.SearchApp.appSearch"
目前支持的插件查询条件有 插件名(appname) 设置的关键词(b_keywords) 可按插件添加日期排序
注:插件必须与宿主绑定才可被查询到
3.插件版本状态查询:
OSGI服务名:com.apkplug.service.update.checkupdate
可批量查询该宿主对应的插件版本状态
4.插件文件下载:
OSGI服务名:"com.apkplug.service.download.AppDownload"
通过查询(2)或插件版本更新功能(3)可获取appBean,通过它可下载插件文件。
二,宿主应用集成插件托管服务
1)插件托管服务是一个jar包我们只需要将其放置于宿主文件夹的libs目录中即可。如图
2)将插件托管的OSGI服务注册到apkplug框架中
详细代码在 com.apkplug.cloudservicedemo.ProxyApplication 类中
try{
//com.apkplug.appServiceManager 为TuoCloudService1.0.0.jar包提供的插件托管服务启动BundleActivator
List activators=new java.util.ArrayList<BundleActivator>();
//将服务加入框架,框架将在启动时启动这些服务
activators.add(new appServiceManager());
frame=FrameworkFactory.getInstance().start(activators,this,new MyProperty(this.getApplicationContext()));
}catch (Exception ex){
System.err.println("Could not create : " + ex);
ex.printStackTrace();
int nPid = android.os.Process.myPid();
android.os.Process.killProcess(nPid);
}
try{
//com.apkplug.appServiceManager 为TuoCloudService1.0.0.jar包提供的插件托管服务启动BundleActivator
List activators=new java.util.ArrayList<BundleActivator>();
//将服务加入框架,框架将在启动时启动这些服务
activators.add(new appServiceManager());
frame=FrameworkFactory.getInstance().start(activators,this,new MyProperty(this.getApplicationContext()));
}catch (Exception ex){
System.err.println("Could not create : " + ex);
ex.printStackTrace();
int nPid = android.os.Process.myPid();
android.os.Process.killProcess(nPid);
}
三, 使用插件托管服务接口查询
上一步我们将托管服务已经全部注册到apkplug框架里面了,所以当使用时只需要找到服务,如下为模板代码:
注:代码位置 com.apkplug.cloudservicedemo.activity.SearchActivity
/**
* appSearch 插件搜索服务
* @param context 插件上下文
* @param bean 查询条件填充 bean
* @param callback 查询结果回调接口
*/
public void search(BundleContext context,appSearchBean bean,AppSearchCallBack callback){
ServiceReference reference=context.getServiceReference(appSearch.class.getName());
if(null!=reference){
appSearch service=(appSearch)context.getService(reference);
if(service!=null){
service.search(bean,callback);
}
context.ungetService(reference);
}
}
/**
* appSearch 插件搜索服务
* @param context 插件上下文
* @param bean 查询条件填充 bean
* @param callback 查询结果回调接口
*/
public void search(BundleContext context,appSearchBean bean,AppSearchCallBack callback){
ServiceReference reference=context.getServiceReference(appSearch.class.getName());
if(null!=reference){
appSearch service=(appSearch)context.getService(reference);
if(service!=null){
service.search(bean,callback);
}
context.ungetService(reference);
}
}
以上有两个需要我们填充
appSearchBean bean 是插件条件bean ,我们可以通过填充它来设置一些查询条件
AppSearchCallBack callback 查询过程或结果将通过该接口返回
public void updataDate(BundleContext context){
bean=new appSearchBean();
//按插件被添加到分组(宿主)的时间逆序查询
bean.setG_order(appSearchBean.order_desc);
//插件的关键词keyword
bean.setB_keywords("工具");
bean.setPagenum(10);
bean.setPage(0);
//查询
search(context,bean,new impAppSearchCallBack());
}
public void updataDate(BundleContext context){
bean=new appSearchBean();
//按插件被添加到分组(宿主)的时间逆序查询
bean.setG_order(appSearchBean.order_desc);
//插件的关键词keyword
bean.setB_keywords("工具");
bean.setPagenum(10);
bean.setPage(0);
//查询
search(context,bean,new impAppSearchCallBack());
}
class impAppSearchCallBack implements AppSearchCallBack{
public void onFailure(int arg0, final String arg1) {
//服务查询失败
}
public void onSuccess(int stutas, CallBackMSG msg,appSearchBean arg2) {
//服务查询成功
if(stutas>=0){
if(msg.getStutes()>=0){
//查询正确
//获取查询到的插件
List<appBean> aps=(List)msg.getMsg();
}else{
//查询条件异常
}
}else{
//网络异常
}
}
}
class impAppSearchCallBack implements AppSearchCallBack{
public void onFailure(int arg0, final String arg1) {
//服务查询失败
}
public void onSuccess(int stutas, CallBackMSG msg,appSearchBean arg2) {
//服务查询成功
if(stutas>=0){
if(msg.getStutes()>=0){
//查询正确
//获取查询到的插件
List<appBean> aps=(List)msg.getMsg();
}else{
//查询条件异常
}
}else{
//网络异常
}
}
}
注:查询完成后返回的appSearchBean arg2可以获取到该条件下服务端插件总体数量以及当前返回页