1

我正在使用 spring 的 Jaxb2Marshaller(没有 Web 服务)来解组一些 xml。xml 代码是通过 maven-jaxb-plugin 生成的代码,我在 spring 中通过以下方式实例化 Jaxb2Marshaller:

<bean id="unmarshaller" class="...Jaxb2Marshaller" p:contextPath="my.package.path" />  

然后开始:

mvn clean package
mvn tomcat:run 

第一个解组器创建得很好,第二个抛出 org.springframework.oxm.jaxb.JaxbSystemException 因为它找不到 ObjectFactory (由 maven-jaxb-plugin 生成,我已经验证它实际上存在于jar,在正确的包中)。

我实际上有两个解组器,(尽管我尝试使用一个解组器和 contextPath 用冒号分隔的包路径,结果相同)。

我认为这通常不是 spring 或我的配置的问题,因为如果我部署到一个完整的 tomcat 容器中,它可以正常工作。我确实注意到 maven 将 tomcat 放在我的 project/target/tomcat 文件夹中,并且存在一些差异,例如没有 lib 目录。我实际上不知道嵌入式 tomcat 和常规安装之间的所有区别。

有人可以解释一下:
1)嵌入式tomcat与常规安装有何不同
2)是否存在已知限制
3)是否可以配置为在这种情况下正常工作

完整的堆栈跟踪:

SEVERE: Exception sending context initialized event to listener instance of class org.springframework.web.context.ContextLoaderListener
org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'unmarshaller' defined in class path resource [spring.xml]: Invocation of init method failed; nested exception is org.springframework.oxm.jaxb.JaxbSystemException: "my.package.path" doesnt contain ObjectFactory.class or jaxb.index; nested exception is javax.xml.bind.JAXBException: "my.package.path" doesnt contain ObjectFactory.class or jaxb.index
    at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.initializeBean(AbstractAutowireCapableBeanFactory.java:1338)
    at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:473)
    at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory$1.run(AbstractAutowireCapableBeanFactory.java:409)
    at java.security.AccessController.doPrivileged(Native Method)
    at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:380)
    at org.springframework.beans.factory.support.AbstractBeanFactory$1.getObject(AbstractBeanFactory.java:264)
    at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:222)
    at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:261)
    at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:185)
    at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:164)
    at org.springframework.beans.factory.support.DefaultListableBeanFactory.preInstantiateSingletons(DefaultListableBeanFactory.java:429)
    at org.springframework.context.support.AbstractApplicationContext.finishBeanFactoryInitialization(AbstractApplicationContext.java:728)
    at org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:380)
    at org.springframework.web.context.ContextLoader.createWebApplicationContext(ContextLoader.java:255)
    at org.springframework.web.context.ContextLoader.initWebApplicationContext(ContextLoader.java:199)
    at org.springframework.web.context.ContextLoaderListener.contextInitialized(ContextLoaderListener.java:45)
    at org.apache.catalina.core.StandardContext.listenerStart(StandardContext.java:4135)
    at org.apache.catalina.core.StandardContext.start(StandardContext.java:4630)
    at org.apache.catalina.core.ContainerBase.start(ContainerBase.java:1045)
    at org.apache.catalina.core.StandardHost.start(StandardHost.java:785)
    at org.apache.catalina.core.ContainerBase.start(ContainerBase.java:1045)
    at org.apache.catalina.core.StandardEngine.start(StandardEngine.java:445)
    at org.apache.catalina.startup.Embedded.start(Embedded.java:825)
    at org.codehaus.mojo.tomcat.AbstractRunMojo.startContainer(AbstractRunMojo.java:558)
    at org.codehaus.mojo.tomcat.AbstractRunMojo.execute(AbstractRunMojo.java:255)
4

1 回答 1

2

对于遇到此问题的其他人,我最终通过使用 classesToBeBound 属性而不是 contextPath 解决了这个问题。我最初避免使用 classesToBeBound 的原因是我认为我必须在 classesToBeBound 列表中指定模型中的每个类,但事实并非如此。您只需指定具有 @XmlRootElement 注释的类。

于 2011-03-02T16:13:49.593 回答