1.问题描述
OSGI的equinox框架开发程序,引用dom4j包编译没有错误,但运行后就报错:
Root exception:
java.lang.NoClassDefFoundError:org/dom4j/io/OutputFormat
2.问题查找
经查资料分析自己写的bundle运行目录是在workspace下.metadata/plugin下,但未在此位置找到自定义的bundle,仅有OSGI框架相关的bundle,看不到dom4j包有没有拷贝过来 失败!
然后发现出错控制台提示OSGI运行的命令行里有个dev.properties文件,打开后发现里面配置的了各个自定义bundle的引用jar包路径,貌似有点线索了。但此文件无法手动修改,运行时候自动生成,需要继续查找。
忽然想到可以把自定义bundle打包下看看里面有没有dom4j,打包后果然没有! 但项目中classpath明明配好的,编译没有问题为什么会没有呢?
查看了下项目的MANIFEST.MF文件,发现bundle-Classpath有其他两个包的显式定义,却缺少了dom4j,看来是这里的问题了。
添加后重新运行果然可以。
至此问题已解决,但是这其中过程有点曲折了。此问题也反应出OSGI的jar包管理与普通项目的不一样的地方,一般项目classpath配置好即可,但OSGI的classpath配置和bundle-Classpath配置不会自动同步,大概是为了多bundle不用重复引用相同的jar包吧。实际还需深入研究下,先写到这。