Java 让RestEASY、HIbernate、Maven和JBossAS5.1更好地发挥作用
我正在尝试构建一个使用hibernate进行数据访问的restful Web服务。我正在使用Maven进行构建,并且必须在JBossAS5.1上部署—将来可能是EAP5.x RestEASY很好,但Hibernate有问题,只要我将Hibernate依赖项添加到pom.xml中,部署后产生的WAR就会立即崩溃 我对Java和Maven相当熟悉,但除了简单的JSP之外,我对JavaEE还是新手 pom.xml摘录:Java 让RestEASY、HIbernate、Maven和JBossAS5.1更好地发挥作用,java,hibernate,maven,jboss5.x,Java,Hibernate,Maven,Jboss5.x,我正在尝试构建一个使用hibernate进行数据访问的restful Web服务。我正在使用Maven进行构建,并且必须在JBossAS5.1上部署—将来可能是EAP5.x RestEASY很好,但Hibernate有问题,只要我将Hibernate依赖项添加到pom.xml中,部署后产生的WAR就会立即崩溃 我对Java和Maven相当熟悉,但除了简单的JSP之外,我对JavaEE还是新手 pom.xml摘录: <repositories> <
<repositories>
<repository>
<id>jboss</id>
<name>jboss repo</name>
<url>http://repository.jboss.org/nexus/content/groups/public/</url>
</repository>
</repositories>
<dependencies>
<!-- hibernate -->
<dependency>
<groupId>org.hibernate</groupId>
<artifactId>hibernate-core</artifactId>
<version>3.5.6-Final</version>
<exclusions>
<exclusion>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-api</artifactId>
</exclusion>
</exclusions>
</dependency>
<dependency>
<groupId>javax.persistence</groupId>
<artifactId>persistence-api</artifactId>
<version>1.0</version>
</dependency>
<dependency>
<groupId>org.jboss.resteasy</groupId>
<artifactId>resteasy-jaxrs</artifactId>
<version>2.0.0.GA</version>
<exclusions>
<exclusion>
<groupId>com.sun.xml.bind</groupId>
<artifactId>jaxb-impl</artifactId>
</exclusion>
<exclusion>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-api</artifactId>
</exclusion>
<exclusion>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-simple</artifactId>
</exclusion>
<exclusion>
<groupId>org.slf4j</groupId>
<artifactId>jcl-over-slf4j</artifactId>
</exclusion>
</exclusions>
</dependency>
<dependency>
<groupId>org.jboss.resteasy</groupId>
<artifactId>resteasy-jaxb-provider</artifactId>
<version>2.0.0.GA</version>
<exclusions>
<exclusion>
<groupId>com.sun.xml.bind</groupId>
<artifactId>jaxb-impl</artifactId>
</exclusion>
</exclusions>
</dependency>
<build>
<finalName>hedgehog-rest</finalName>
<plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<configuration>
<source>1.6</source>
<target>1.6</target>
</configuration>
</plugin>
</plugins>
</build>
</project>
下面是错误日志的开头:
20:37:05,848 INFO [TomcatDeployment] deploy, ctxPath=/hedgehog-rest
20:37:06,956 INFO [ConfigurationBootstrap] Adding scanned resource: com.ecs.hedgehog.Echo
20:37:07,057 ERROR [[/hedgehog-rest]] Exception sending context initialized event to listener instance of class org.jboss.resteasy.plugins.server.servlet.ResteasyBootstrap
java.lang.RuntimeException: java.lang.RuntimeException: Unable to instantiate MessageBodyReader
at org.jboss.resteasy.plugins.providers.RegisterBuiltin.register(RegisterBuiltin.java:36)
at org.jboss.resteasy.spi.ResteasyDeployment.start(ResteasyDeployment.java:171)
at org.jboss.resteasy.plugins.server.servlet.ResteasyBootstrap.contextInitialized(ResteasyBootstrap.java:28)
at org.apache.catalina.core.StandardContext.listenerStart(StandardContext.java:3910)
是的,Maven包含的Hibernate jar与JBossAS中的jar相冲突。发现的依赖项范围:
org.hibernate
冬眠核心
3.5.6-最终版本
假如
已解决!:-) 是的,Maven包含的Hibernate jar与JBossAS中的jar相冲突。发现的依赖项范围:
org.hibernate
冬眠核心
3.5.6-最终版本
假如
已解决!:-) 嗯,似乎可以使用添加到hibernate依赖项中的。。。在hibernate依赖项中添加了所提供的,似乎可以正常工作。。。做实验
@Path("/echo")
public class Echo
{
@GET
@Produces("text/*")
@Path("/{message}")
public Response echoService(@PathParam("message") String message)
{
return Response.status(200).entity(message).build();
}
}
20:37:05,848 INFO [TomcatDeployment] deploy, ctxPath=/hedgehog-rest
20:37:06,956 INFO [ConfigurationBootstrap] Adding scanned resource: com.ecs.hedgehog.Echo
20:37:07,057 ERROR [[/hedgehog-rest]] Exception sending context initialized event to listener instance of class org.jboss.resteasy.plugins.server.servlet.ResteasyBootstrap
java.lang.RuntimeException: java.lang.RuntimeException: Unable to instantiate MessageBodyReader
at org.jboss.resteasy.plugins.providers.RegisterBuiltin.register(RegisterBuiltin.java:36)
at org.jboss.resteasy.spi.ResteasyDeployment.start(ResteasyDeployment.java:171)
at org.jboss.resteasy.plugins.server.servlet.ResteasyBootstrap.contextInitialized(ResteasyBootstrap.java:28)
at org.apache.catalina.core.StandardContext.listenerStart(StandardContext.java:3910)
<dependency>
<groupId>org.hibernate</groupId>
<artifactId>hibernate-core</artifactId>
<version>3.5.6-Final</version>
<scope>provided</scope>
</dependency>