あらかじめテキストの壁には申し訳ありませんが、時間を無駄にしないように徹底したかったのです。 :-)Jersey 1.11 RESTful WebサービスをJBoss 6.1に展開するFinal(RestEasyはすでに展開されていません)
JBossがTomcatをコンポーネントとして使用しているため、Tomcat 7にRESTful WebサービスをWARファイルとしてデプロイしてテストしましたが、私は(誤って)展開がWARファイルを削除するほど簡単だと考えました私のJBoss 6.1サーバー/ default/deployディレクトリに入れてください。最初はJAX-RSアプリケーションクラスが1つしかないというエラーが出ましたが、これはJbossのdeployers/dirから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日を研究し、壁に向かって頭を叩いた。