【问题标题】:Deploying a Jersey 1.11 RESTful Web service in JBoss 6.1 Final (RestEasy already undeployed)在 JBoss 6.1 Final 中部署 Jersey 1.11 RESTful Web 服务(RestEasy 已取消部署)
【发布时间】:2024-01-18 08:48:02
【问题描述】:

提前对文字墙表示抱歉,但我想彻底,以免浪费您的时间,善良的 * 人。 :-)

我已经在 Tomcat 7 中成功部署并测试了一个 RESTful Web 服务作为 war 文件,因为 JBoss 使用 Tomcat 作为组件,我(错误地)认为部署就像将 war 文件放入我的 JBoss 6.1 一样简单server/default/deploy 目录,不!起初我得到一个错误,说只允许一个 JAX-RS 应用程序类,这很容易通过从 Jboss 中的 deployers/ 目录中删除 resteasy.deployer 来解决(所有,默认和标准服务器只是为了彻底)。

现在关键是我在 Jboss 启动期间收到以下消息:



    10:38:07,431 INFO  [PackagesResourceConfig] Scanning for root resource and provider classes in the packages:
    net.ussouth.incomm.SPIL.resource
    10:38:07,486 INFO  [WebApplicationImpl] Initiating Jersey application, version 'Jersey: 1.11 12/09/2011 10:27 AM'
    10:38:07,718 SEVERE [RootResourceUriRules] The ResourceConfig instance does not contain any root resource classes.
    10:38:07,719 ERROR [[/SPIL]] StandardWrapper.Throwable: com.sun.jersey.api.container.ContainerException: The ResourceConfig instance does not contain any root resource classes.
        at com.sun.jersey.server.impl.application.RootResourceUriRules.(RootResourceUriRules.java:99) [:1.11]
        at com.sun.jersey.server.impl.application.WebApplicationImpl._initiate(WebApplicationImpl.java:1298) [:1.11]
        at com.sun.jersey.server.impl.application.WebApplicationImpl.access$700(WebApplicationImpl.java:169) [:1.11]
        at com.sun.jersey.server.impl.application.WebApplicationImpl$13.f(WebApplicationImpl.java:775) [:1.11]
        at com.sun.jersey.server.impl.application.WebApplicationImpl$13.f(WebApplicationImpl.java:771) [:1.11]

这是 WEB-INF/classes 目录下的资源类:



    package net.ussouth.incomm.SPIL.resource;

    import javax.ws.rs.Path;
    import javax.ws.rs.POST;
    import javax.ws.rs.Consumes;
    import javax.ws.rs.core.MediaType;
    import javax.ws.rs.Produces;
    import javax.ws.rs.FormParam;

    import org.apache.log4j.Logger;

    @Path("/message")
    public class MessageResource {
      private static Logger log = Logger.getLogger(MessageResource.class);


      @POST
      @Path("/Search")
      @Produces(MediaType.APPLICATION_XML)
      @Consumes(MediaType.APPLICATION_FORM_URLENCODED)
      public String search(@FormParam("message") String _msgToProvider, @FormParam("provider") String _provData) {
        log.info("MesageResource.search method called");
        String outVal = null;

        try{
          ProviderHandler hnd = new ProviderHandler();
          outVal = hnd.getOffers(_msgToProvider);

        } catch(JAXBException ex) {
          ...
        } catch (SearchException ex) {
          ...
        }

        return outVal;
      }     
    }

这是 web.xml:

<?xml version="1.0" encoding="UTF-8"?>
<web-app 
  xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  xmlns="http://java.sun.com/xml/ns/javaee"
  xmlns:web="http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd"
  xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd"
  id="WebApp_ID" 
  version="2.5">

  <display-name>Spil</display-name>
  <welcome-file-list>
    <welcome-file>index.html</welcome-file>
  </welcome-file-list>

  <servlet>
    <servlet-name>SpilMessageService</servlet-name>
    <servlet-class>com.sun.jersey.spi.container.servlet.ServletContainer</servlet-class>

    <init-param>
      <param-name>com.sun.jersey.config.property.packages</param-name>
      <param-value>net.ussouth.incomm.SPIL.resource</param-value>
    </init-param>

    <init-param>
      <param-name>log4j-properties-location</param-name>
      <param-value>classes/log4j.xml</param-value>
    </init-param>

    <load-on-startup>1</load-on-startup>
  </servlet>
  <servlet-mapping>
    <servlet-name>SpilMessageService</servlet-name>
    <url-pattern>/*</url-pattern>
  </servlet-mapping>

</web-app>

最后,这里是 jboss-web.xml:

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE jboss-web PUBLIC "-//JBoss//DTD Web Application 2.4//EN" "http://www.jboss.org/j2ee/dtd/jboss-web_4_2.dtd">
<jboss-web>
    <context-root>SPIL</context-root>
</jboss-web>

感谢您的帮助。我已经花了 1.5 天的时间研究并将我的头撞到墙上。

【问题讨论】:

    标签: rest jboss jersey


    【解决方案1】:

    您只需要使用可移植的 JAX-RS 部署方法,如 here 所述。不要使用包扫描,而是使用javax.ws.rs.core.Application的实现强制手动扫描

    import java.util.HashSet;
    import java.util.Set;
    import javax.ws.rs.core.Application;
    
    public class MyApplication extends Application {
        @Override
        public Set<Class<?>> getClasses() {
            final Set<Class<?>> classes = new HashSet<Class<?>>();
            // register resources
            classes.add(MessageResource.class);
            return classes;
        }
    }
    

    然后,更新您的 web.xml 以使用它。请记住禁用resteasy扫描,如下所示。

    <?xml version="1.0" encoding="UTF-8"?>
        <web-app
            xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
            xmlns="http://java.sun.com/xml/ns/javaee"
            xmlns:web="http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd"
            xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd"
            id="WebApp_ID"
            version="2.5">
    
        <display-name>Spil</display-name>
        <welcome-file-list>
            <welcome-file>index.html</welcome-file>
        </welcome-file-list>
    
        <servlet>
            <servlet-name>SpilMessageService</servlet-name>
            <servlet-class>com.sun.jersey.spi.container.servlet.ServletContainer</servlet-class>
    
            <init-param>
                <param-name>javax.ws.rs.Application</param-name>
                <param-value>net.ussouth.incomm.SPIL.resource.MyApplication</param-value>
            </init-param>
    
            <init-param>
                <param-name>log4j-properties-location</param-name>
                <param-value>classes/log4j.xml</param-value>
            </init-param>
    
            <load-on-startup>1</load-on-startup>
        </servlet>
        <context-param>
            <param-name>resteasy.scan</param-name>
            <param-value>false</param-value>
        </context-param>
        <context-param>
            <param-name>resteasy.scan.providers</param-name>
            <param-value>false</param-value>
        </context-param>
        <context-param>
            <param-name>resteasy.scan.resources</param-name>
            <param-value>false</param-value>
        </context-param>
    
        <servlet-mapping>
            <servlet-name>SpilMessageService</servlet-name>
            <url-pattern>/*</url-pattern>
        </servlet-mapping>
    
    </web-app>
    

    【讨论】:

      【解决方案2】:

      奥尔夫

      我遇到了同样的问题(Jersey 1.11 + tomcat 7)。但是在我换成tomcat 6之后,球衣就可以了!

      我不知道为什么,但我建议你改变并尝试。

      【讨论】: