一、在Activator中注册和引用服务
该方式可以说是最原始的方法,首先在MANIFEST.MF中配置需要导入的服务接口MyService(Import-Package: org.jack.MyService),然后采用硬编码方式注册服务:
public class MyActivator implements BundleActivator { private ServiceRegistration serviceRegistration = null; /* * 发布服务 */ public void start(BundleContext context) throws Exception { ServiceRegistration = context.registerService(MyService.class.getName(), new MyServiceImpl(), null); } /* * 卸载服务 */ public void stop(BundleContext context) throws Exception { if(serviceRegistration != null){ serviceRegistration.unregister(); } } }
start方法会在bundle start时调用,stop会在bundle stop时调用;
引用服务时也需要在MANIFEST.MF中配置需要导入的服务接口所在的package,并通过硬编码方式获取服务:
public void start(BundleContext context) throws Exception { ServiceReference reference = context.getServiceReference(MyService.class.getName()); if(reference != null){ MyService my = (MyService)context.getService(reference); } }
其中的reference如果为null,在调用context.getService(reference)时会抛出异常。
二、通过Declarative Service方式注册服务和注入服务引用
将之前的Activator的实现删除,并去掉MANIFEST.MF中配置的Bundle-Activator: org.jack.MyActivator。 在META-INF的同级目录建立OSGI-INF目录,通过eclipse建立Plug-in Development/Component Definition文件,取名component.xml,然后配置发布服务,当然也可以使用图形界面:
<?xml version="1.0" encoding="UTF-8"?> <scr:component xmlns:scr="http://www.osgi.org/xmlns/scr/v1.1.0" name="exportService"> <implementation class="org.jack.impl.MyServiceImpl"/> <service> <provide interface="org.jack.MyService"/> </service> </scr:component>
要引用服务,同样要建立OSGI-INF/component.xml文件,配置如下:
<?xml version="1.0" encoding="UTF-8"?> <scr:component xmlns:scr="http://www.osgi.org/xmlns/scr/v1.1.0" name="importService"> <implementation class="org.jack.MyServlet"/> <reference bind="setMyService" cardinality="1..1" interface="org.jack.MyService" name="MyService" policy="dynamic" unbind="unsetMyService"/> </scr:component>
在此我们建立了一个servlet(通过继承HttpServlet),并添加了setMyService方法和unsetMyService方法用于注入和取消注入服务引用。
以上使用DS方式注入,都需要在META-INF中配置Service-Component: OSGI-INF/component.xml以便指定引用的文件。