【问题标题】:Getting RestEASY, HIbernate, Maven and JBossAS5.1 to play nicely让 RestEASY、HIbernate、Maven 和 JBossAS5.1 玩得很好
【发布时间】:2010-12-20 05:18:22
【问题描述】:

我正在尝试构建一个使用休眠进行数据访问的宁静 Web 服务。我正在使用 Maven 构建并且必须在 JBossAS5.1 上部署 - 将来可能是 EAP5.x。

RestEASY 很好,但是我在使用 Hibernate 时遇到了问题,一旦我将休眠依赖项添加到 pom.xml,生成的 WAR 会在部署后立即崩溃。

我对 Java 和 Maven 相当熟悉,但对 JavaEE 不熟悉,而不仅仅是简单的 JSP。

pom.xml 提取:

      <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>

web.xml:

<web-app>
   <display-name>Archetype Created Web Application</display-name>
   <context-param>
      <param-name>resteasy.scan</param-name>
      <param-value>true</param-value>
   </context-param>
   <listener>
      <listener-class>org.jboss.resteasy.plugins.server.servlet.ResteasyBootstrap</listener-class>
   </listener>
   <servlet>
      <servlet-name>Resteasy</servlet-name>
      <servlet-class>org.jboss.resteasy.plugins.server.servlet.HttpServletDispatcher</servlet-class>
   </servlet>
   <servlet-mapping>
      <servlet-name>Resteasy</servlet-name>
      <url-pattern>/*</url-pattern>
   </servlet-mapping>
</web-app>

我删除了除此类之外的所有代码:

@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)

【问题讨论】:

  • hmmm,添加到休眠依赖项的 provided 似乎可以正常工作...正在试验

标签: java hibernate maven jboss5.x


【解决方案1】:

是的,Maven 包含的 Hibernate JAR 与 JBossAS 中的 JAR 冲突。发现依赖范围:http://maven.apache.org/guides/introduction/introduction-to-dependency-mechanism.html#Dependency_Scope

<dependency>
  <groupId>org.hibernate</groupId>
  <artifactId>hibernate-core</artifactId>
  <version>3.5.6-Final</version>
  <scope>provided</scope>
</dependency>     

解决了! :-)

【讨论】:

    猜你喜欢
    • 2011-03-16
    • 1970-01-01
    • 2014-03-18
    • 2011-09-14
    • 2011-09-17
    • 2010-11-28
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多