2011-09-15 18 views
3

私はtomcatとjerseyには新しくなっています。うまくいけば、これはばかげた間違いではありません。私はページの読み込み時に500エラーが発生するTomcat

javax.servlet.ServletException: Servlet.init() for servlet Jersey REST Service threw exception 
org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:472) 
org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:100) 
org.apache.catalina.valves.AccessLogValve.invoke(AccessLogValve.java:929) 
org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:405) 
org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:269) 
org.apache.coyote.AbstractProtocol$AbstractConnectionHandler.process(AbstractProtocol.java:515) 
org.apache.tomcat.util.net.JIoEndpoint$SocketProcessor.run(JIoEndpoint.java:302) 
java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1110) 
java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:603) 
java.lang.Thread.run(Thread.java:679) 

root cause 

com.sun.jersey.api.container.ContainerException: The ResourceConfig instance does not  contain any root resource classes. 
com.sun.jersey.server.impl.application.RootResourceUriRules.<init> (RootResourceUriRules.java:99) 
com.sun.jersey.server.impl.application.WebApplicationImpl._initiate(WebApplicationIm pl.java:1298) 
com.sun.jersey.server.impl.application.WebApplicationImpl.access$700(WebApplicationImpl.java:169) 
com.sun.jersey.server.impl.application.WebApplicationImpl$13.f(WebApplicationImpl.java:775) 
com.sun.jersey.server.impl.application.WebApplicationImpl$13.f(WebApplicationImpl.java:771) 
com.sun.jersey.spi.inject.Errors.processWithErrors(Errors.java:193) 
com.sun.jersey.server.impl.application.WebApplicationImpl.initiate(WebApplicationImpl.java:771) 
com.sun.jersey.server.impl.application.WebApplicationImpl.initiate(WebApplicationImpl.java:766) 
com.sun.jersey.spi.container.servlet.ServletContainer.initiate(ServletContainer.java:488) 
com.sun.jersey.spi.container.servlet.ServletContainer$InternalWebComponent.initiate(ServletContainer.java:318) 
com.sun.jersey.spi.container.servlet.WebComponent.load(WebComponent.java:609) 
com.sun.jersey.spi.container.servlet.WebComponent.init(WebComponent.java:210) 
com.sun.jersey.spi.container.servlet.ServletContainer.init(ServletContainer.java:373) 
com.sun.jersey.spi.container.servlet.ServletContainer.init(ServletContainer.java:556) 
javax.servlet.GenericServlet.init(GenericServlet.java:160) 
org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:472) 
org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:100) 
org.apache.catalina.valves.AccessLogValve.invoke(AccessLogValve.java:929) 
org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:405) 
org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:269) 
org.apache.coyote.AbstractProtocol$AbstractConnectionHandler.process(AbstractProtocol.java:515) 
org.apache.tomcat.util.net.JIoEndpoint$SocketProcessor.run(JIoEndpoint.java:302) 
java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1110) 
java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:603) 
java.lang.Thread.run(Thread.java:679) 

...私は次のエラーを取得する私のプロジェクトは、http://127.0.0.1:8080/first/rest/helloに位置しようとすると、アクセスするたびに私は、Javaクラスと、このプロジェクトのweb.xmlファイルを持っています。彼らは以下の通りです...

Hello.java

import javax.ws.rs.GET; 
import javax.ws.rs.Path; 
import javax.ws.rs.Produces; 
import javax.ws.rs.core.MediaType; 

@Path("/hello") 
public class Hello { 

// This method is called if TEXT_PLAIN is request 
@GET 
@Produces(MediaType.TEXT_PLAIN) 
public String sayPlainTextHello() { 
    return "Hello Jersey"; 
} 

// This method is called if XML is request 
@GET 
@Produces(MediaType.TEXT_XML) 
public String sayXMLHello() { 
    return "<?xml version=\"1.0\"?>" + "<hello> Hello Jersey" + "</hello>"; 
} 

// This method is called if HTML is request 
@GET 
@Produces(MediaType.TEXT_HTML) 
public String sayHtmlHello() { 
    return "<html> " + "<title>" + "Hello Jersey" + "</title>" 
      + "<body><h1>" + "Hello Jersey" + "</body></h1>" + "</html> "; 
} 

} 

web.xmlの

​​3210

私は何をしないのですか?

EDIT:私は、以下のチュートリアルを使用して開始していると思われます。 http://www.vogella.de/articles/REST/article.html#first

+0

を使用します。http://jersey.576304.n2.nabble.com/The-ResourceConfig- instance-does-not-contain-any-root-resource-classes-td1519918.html –

+0

動作していないようです。ちょうど今私に404を与える。 – Skizit

答えて

8

最良の方法は、テスト済みの作業サンプルを見てみることです。

のHelloWorld-webappの::..だから、次を参照してください

ところでhttps://maven.java.net/content/repositories/releases/com/sun/jersey/samples/helloworld-webapp/1.9.1/helloworld-webapp-1.9.1-gf-project.zipは、そのエラーメッセージが意味「ジャージーはANY @Path注釈付きクラスを見つけることができません」。

<init-param> 
    <param-name>com.sun.jersey.config.property.packages</param-name> 
    <param-value>first</param-value> 
</init-param> 

「Hello」クラスが存在するパッケージの「最初の」実際の名前はありますか?ジャージー2.xのドキュメントで

+0

ここのパスは間違っていた。ありがとう! – Skizit

1

あなたはこのページの2番目の答えを見れば、それはあなたを助けるかもしれ

<init-param> 
    <param-name>jersey.config.server.provider.packages</param-name> 
    <param-value>com.rest.portal</param-value> 
</init-param> 
関連する問題