当前位置: 首页 > 知识库问答 >
问题:

JAXB OSGi与Java11

楚灿
2023-03-14

我正尝试使用POM优先的方法(生成OSGi元数据)将JAXB模块作为OSGi包加载到Java11和ApacheFelix中。

首先,我尝试了:

        <dependency>
            <groupId>com.sun.xml.bind</groupId>
            <artifactId>jaxb-osgi</artifactId>
            <version>2.3.3</version>
        </dependency>

但这给了我以下运行时例外:

SCHWERWIEGEND: Implementation of JAXB-API has not been found on module path or classpath.  
javax.xml.bind.JAXBException: Implementation of JAXB-API has not been found on module path or classpath.
 - with linked exception: 
[java.lang.ClassNotFoundException: com.sun.xml.bind.v2.ContextFactory]

这可能与以下问题有关,但我不确定:https://github.com/eclipse-ee4j/jaxb-api/issues/78

所以我尝试了v3。0.0但现在我的一个注释处理程序使用JAXB生成XML文档,失败了:

Failed to execute goal org.apache.maven.plugins:maven-compiler-plugin:3.8.1:compile (default-compile) on project my-module: Compilation failure
Implementation of JAXB-API has not been found on module path or classpath.

我注意到jaxb-osgi-3.0.0.jar不再提供com.sun.xml.bind包了

我还尝试从javax.xml.bind迁移到jakarta.xml.bind,但是从XSD生成POJO类的Maven插件在编写时似乎还没有准备好(既不是<##############################################################################################################################################

我的问题:

  1. 我从哪里可以得到com.sun.xml.bind
  2. jaxb-osgi和jaxb-impl模块是如何关联的?
  3. 这一切应该如何工作?
  4. 我如何继续?

更新-背景资料

我有以下基于扩展器模式的设置:

  • 核心扩展器模块M:
  • 提供额外的JAXB类(从XSD生成)
  • 使用声明性服务注册扩展
  • 自定义批注
  • 注释处理器将注释属性转换为基于JAXB的模型,并在预期位置生成XML文档
  • 使用模块A、B、C的注释
  • 使用A、B、C的注释处理器生成XML文档

目标:应该很容易创建扩展模块,如X、Y、Z

在JavaSE8中一切正常,JAXB仍然与JRE捆绑在一起。

更新1

因为Maven插件还没有准备好,我只能使用v2。3.3现在。

我更改了以下内容:

>

  • 调用JAXBContext.new实例时,我提供了一个类加载器

    我在几个模块中为maven-bundle插件添加了以下配置:

    这解决了ClassNotFoundExcture:com.sun.xml.bind.v2java.lang.。ContextFactory问题(虽然它似乎不是正确的解决方案),但是现在对象工厂无法定位,尽管它们已经生成。

    更新2

    我现在使用的是一个经过修改的jaxb-osgi捆绑包(见问题)和Apache-Aries-SPI-Fly动态编织捆绑包(1.3.2)(osgi-ServiceLoader-Mediator规范的参考实现),我向核心模块m添加了以下要求:

    Require-Capability: [...],osgi.extender;filter:="(o
     sgi.extender=osgi.serviceloader.processor)",osgi.serviceloader;filter:=
     "(osgi.serviceloader=javax.xml.bind.JAXBContextFactory)";cardinality:=m
     ultiple,[...]"
    

    这些服务似乎被检测到:

    2021-02-13 12:09:31 INFO org.apache.aries.spifly.BaseActivator log - Registered provider com.sun.xml.bind.v2.JAXBContextFactory of service javax.xml.bind.JAXBContextFactory in bundle com.sun.xml.bind.jaxb-osgi
    2021-02-13 12:09:31 INFO org.apache.aries.spifly.BaseActivator log - Registered provider com.sun.tools.xjc.addon.code_injector.PluginImpl of service com.sun.tools.xjc.Plugin in bundle com.sun.xml.bind.jaxb-osgi
    2021-02-13 12:09:31 INFO org.apache.aries.spifly.BaseActivator log - Registered provider com.sun.tools.xjc.addon.locator.SourceLocationAddOn of service com.sun.tools.xjc.Plugin in bundle com.sun.xml.bind.jaxb-osgi
    2021-02-13 12:09:31 INFO org.apache.aries.spifly.BaseActivator log - Registered provider com.sun.tools.xjc.addon.sync.SynchronizedMethodAddOn of service com.sun.tools.xjc.Plugin in bundle com.sun.xml.bind.jaxb-osgi
    2021-02-13 12:09:31 INFO org.apache.aries.spifly.BaseActivator log - Registered provider com.sun.tools.xjc.addon.at_generated.PluginImpl of service com.sun.tools.xjc.Plugin in bundle com.sun.xml.bind.jaxb-osgi
    2021-02-13 12:09:31 INFO org.apache.aries.spifly.BaseActivator log - Registered provider com.sun.tools.xjc.addon.episode.PluginImpl of service com.sun.tools.xjc.Plugin in bundle com.sun.xml.bind.jaxb-osgi
    2021-02-13 12:09:31 INFO org.apache.aries.spifly.BaseActivator log - Registered provider com.sun.tools.xjc.addon.accessors.PluginImpl of service com.sun.tools.xjc.Plugin in bundle com.sun.xml.bind.jaxb-osgi
    

    但我仍然得到:

    javax.xml.bind.JAXBException: Implementation of JAXB-API has not been found on module path or classpath.
     - with linked exception:
    [java.lang.ClassNotFoundException: com.sun.xml.bind.v2.ContextFactory not found by 
    

    为什么它尝试加载硬编码的默认com.sun.xml.bind.v2。ContextFactory而不是com.sun.xml.bind.v2。JAXB ContextFactory通过ServiceLoader?


  • 共有1个答案

    诸经略
    2023-03-14

    由于每个OSGI包都使用自己的类加载器,因此JAXB API无法使用标准的ServiceLoader来定位JAXB实现。但是,自版本2.2.2以来,JAXB API可以使用osgi资源定位器作为后备方案。

    因此,为了在Java 11上使用JAXB,您只需要:

    1. javax上添加依赖项。xml。绑定组织。玻璃鱼。香港2。osgiresourcelocator软件包,
    2. osgi资源定位器jaxb osgi捆绑包与您的捆绑包一起部署

    备注:如果您想使用MOXy,您需要额外的步骤,因为MOXy没有附带META-INF/services/javax。xml。绑定JAXBContext文件(参见此答案)。

     类似资料:
    • 在C语言中,假设每个算法被赋予完全相同的一组进程,那么先到先得、最短作业优先和循环之间的周转时间是否相等?还是调度算法不同?

    • 问题内容: 为了为 HTML5 Doctype 定义字符集,我应该使用哪种表示法? 短: 长: 问题答案: 在HTML5中,它们是等效的。使用较短的一个,更容易记住和键入。浏览器支持很好,因为它是为向后兼容而设计的。

    • 连接的多个输入都相当于Yes的时候才会输出Yes。 用法 Your browser does not support the video tag. 案例:小闹钟 功能:今天15:10:00,响起猫叫声小闹钟 工作原理 当所有的输入都是Yes的时候,与节点才输出Yes。

    • 问题内容: 似乎有三种 相同的 方法可以独立于平台获取依赖于平台的“文件分隔符”: 我们如何决定何时使用哪个? 它们之间甚至有什么区别吗? 问题答案: 可以通过调用命令行参数或使用命令行参数覆盖 获取默认文件系统的分隔符。 获取默认文件系统。 获取文件系统的分隔符。请注意,作为一种实例方法,在需要代码在一个JVM中对多个文件系统进行操作的情况下,可以使用该方法将不同的文件系统传递给代码(而不是默认

    • 问题内容: 我今天刚刚与一些同事讨论了python的db-api fetchone vs fetchmany vs fetchall。 我确定每个应用程序的用例都取决于我正在使用的db-api的实现,但是总的来说,fetchone,fetchmany,fetchall的用例是什么? 换句话说,以下等效项是什么?还是其中之一比其他人更受青睐?如果是这样,在哪些情况下? 问题答案: 我认为这确实取决于