春の 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
最初のアンマーシャラーは正常に作成され、2 番目は org.springframework.oxm.jaxb.JaxbSystemException でスローされます。これは、ObjectFactory (maven-jaxb-plugin によって生成され、実際にjar、正しいパッケージ内)。
私は実際には2つのアンマーシャラーを持っています(ただし、コロンで区切られたパッケージパスを持つ1つのアンマーシャラーとcontextPathで試しましたが、同じ結果が得られました)。
完全なTomcatコンテナにデプロイすると正常に動作するため、これは一般的にSpringまたは私の構成の問題ではないと思います。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)