我将 Felix iPOJO 包装在我的框架中,称之为“MyFramework”,以简化它的一些操作。
使用 MyFramework,我有以下内容:
1-“HelloService”Bundle,它是一个 iPOJO 组件,提供打印“hello”消息作为服务。
2-“MyFrameworkComposite”包,它是另一个 iPOJO 组件,它实例化上面的“HelloService”组件并在其启动方法中检索其服务。
3- 一个启动包,它只是一个 OSGI 包,它在其启动方法中实例化“MyFrameworkComposite”组件。
4- 我的 Java 应用程序加载了 iPOJO 所需的捆绑包,以及上述 3 个捆绑包。
当我运行我的 java 应用程序时,我收到以下带有错误的输出:
MyFramework Hello Service Bundle Started!
MyFramework Composite Bundle Started!
MyFramework Starter Bundle Started!
MyFramework Composite Started!
MyFramework Hello Service Component started!!
hello Component copy State is2
[ERROR] : [adere-composite-0] The callback method start has thrown an exception : loader constraint violation: loader (instance of org/apache/felix/framework/BundleWiringImpl$BundleClassLoaderJava5) previously initiated loading for a different type with name "org/apache/felix/ipojo/handlers/providedservice/ProvidedServiceDescription"
java.lang.LinkageError: loader constraint violation: loader (instance of org/apache/felix/framework/BundleWiringImpl$BundleClassLoaderJava5) previously initiated loading for a different type with name "org/apache/felix/ipojo/handlers/providedservice/ProvidedServiceDescription"
at java.lang.ClassLoader.defineClass1(Native Method)
at java.lang.ClassLoader.defineClassCond(ClassLoader.java:631)
at java.lang.ClassLoader.defineClass(ClassLoader.java:615)
at .....................................(OTHER SIMILAR ERRORS)
done ok (Y)
错误恰好发生在以下行:(此行在我的框架代码中):
public String[] getServiceSpecifications()
{
return this.providedServiceDescription.getServiceSpecifications();//error here
}
providedServiceDescription 的类型为 ProvidedServiceDescription,它是org.apache.felix.ipojo.handlers.providedservice
包的一部分。
尝试在我的“MyFrameworkComposite”组件中检索“Hello Service”组件服务时,到达发生错误的行,如下所示:
ProvidedService ps= content.getProvidedService("myhelloservice.helloservice.HelloService");
我在不同的资源中读到,当您在类路径中有重复的库时,可能会导致这种情况。但我确信事实并非如此。可能是什么原因?