我无法弄清楚为什么会发生以下情况:
我正从一个小型Android应用程序运行嵌入式apache felix。我在启动框架后以编程方式安装了2个bundle,但两者都没有进入“已解决”状态。因此Bundle“MyBundle1”导入“MyBundle2”。
这就是Logcat告诉我的:
05-17 20:21:56.514: ERROR/MainActivity(384): org.osgi.framework.BundleException:
Unresolved constraint in bundle de.xy.MyBundle1 [1]: Unable to resolve 1.11: missing
requirement [1.11] package; (package=de.xy.MyBundle2) [caused by: Unable to resolve 2.0:
missing requirement [2.0] package; (&(package=org.osgi.framework)(version>=1.5.0))]
我完全理解错误消息所说的内容(嗯...版本1.5+中的org.osgi.framework无法解决)但我无法弄清楚为什么会发生这种情况。为什么框架不能解决“他自己”?!我尝试使用adb shell独立运行相同的felix.jar,两个bundle都可以运行。当然,felix.jar是最新的(3.2)
感谢您的建议!
丹尼尔
FelixSetup
m_configMap = new StringMap(false);
try {
m_cache = File.createTempFile("felix-cache", null);
} catch (IOException ex) {
throw new IllegalStateException(ex);
}
m_cache.delete();
boolean mkdirs = m_cache.mkdirs(); // works (=true)
m_activator = new HostActivator(); // implements BundleActivator
List list = new ArrayList();
list.add(m_activator);
m_configMap.put(FelixConstants.LOG_LEVEL_PROP, "1");
m_configMap.put(BundleCache.CACHE_ROOTDIR_PROP, ".");
m_configMap.put(FelixConstants.SYSTEMBUNDLE_ACTIVATORS_PROP, list);
m_configMap.put(FelixConstants.FRAMEWORK_STORAGE, m_cache.getAbsolutePath());
m_felix = new Felix(m_configMap);
try {
m_felix.start();
} catch (BundleException ex) {
Logger.getLogger(MainActivity.class.getName()).log(Level.SEVERE, null, ex);
}
我不知道它是否与以前的问题有关:
05-18 08:52:59.149: VERBOSE/out(363): Problem creating boot delegation class loader: java.lang.reflect.InvocationTargetException
05-18 08:52:59.209: VERBOSE/out(363): ERROR: Error parsing system bundle export statement: (java.lang.IllegalArgumentException:A header cannot be an empty string.)
05-18 08:52:59.209: VERBOSE/out(363): java.lang.IllegalArgumentException: A header cannot be an empty string.
我使用
安装并启动捆绑包myBundle1= bundleContext.installBundle("file:/data/felix/MyBundle1.jar");
myBundle2= bundleContext.installBundle("file:/data/felix/MyBundle2.jar");
myBundle1.start();
他们之前是dx'ed并使用 adb push 移至/ data / felix。
我在android-application中使用的相同代码也适用于常规的java console-app。
答案 0 :(得分:2)
构建框架的方式对我来说没问题。你可以考虑
FRAMEWORK_SYSTEMPACKAGES
,如果您的捆绑包例如使用活动)或我们过去成功使用过3.0.1,并且我确实认为您发布的错误消息与它有关。您可以尝试使用该版本的Felix,如果可以,您可能在Felix中找到了回归,然后您可以向users@felix.apache.org报告。