ここでステップ6.3まで説明されている詳細に従って、ジャージー(Tomcatサーバーを使用)を構成しました。 http://www.vogella.com/tutorials/REST/article.html#jerseyprojectsetup
以下は私のweb.xmlファイルです。唯一の違いは、jersey.config.server.provider.packages
のパス/パッケージ名です
指示があります。
<param-name>jersey.config.server.provider.packages</param-name>
<param-value>com.vogella.jersey.first</param-value>
com.vogella.jersey.first
はパッケージ名であり、デフォルトのパッケージ(jerseytest)を指すように選択したためです。
しかし、これは私の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" xsi:schemaLocation="http://Java.Sun.com/xml/ns/javaee http://Java.Sun.com/xml/ns/javaee/web-app_3_0.xsd" id="WebApp_ID" version="3.0">
<display-name>jerseytest</display-name>
<servlet>
<servlet-name>Jersey REST Service</servlet-name>
<servlet-class>org.glassfish.jersey.servlet.ServletContainer</servlet-class>
<!-- Register resources and providers under com.vogella.jersey.first package. -->
<init-param>
<param-name>jersey.config.server.provider.packages</param-name>
<param-value>jerseytest</param-value>
</init-param>
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>Jersey REST Service</servlet-name>
<url-pattern>/rest/*</url-pattern>
</servlet-mapping>
</web-app>
tomcatサーバーでアプリケーションを実行すると、次の情報が得られます。
HTTPステータス404 –見つかりません
タイプステータスレポート
Message /jerseytest/
説明Originサーバーは、ターゲットリソースの現在の表現を見つけられなかったか、存在することを開示しません。
Apache Tomcat/8.5.23
そして、チュートリアルで言及されたエンドポイントにブラウザを向けると:http://localhost:8080/com.vogella.jersey.first/rest/hello
エラーが見つかりません:
HTTPステータス404 –見つかりません
タイプステータスレポート
Message Not Found
説明Originサーバーは、ターゲットリソースの現在の表現を見つけられなかったか、存在することを開示しません。
Apache Tomcat/8.5.23
ブラウザで http:// localhost:8080/rest/hello を直接ポイントすると
私は得る:
HTTPステータス404 –見つかりません
タイプステータスレポート
Message /rest/hello
説明Originサーバーは、ターゲットリソースの現在の表現を見つけられなかったか、存在することを開示しません。
Apache Tomcat/8.5.23
My Javaクラスは、私のものがデフォルトのパッケージにあることを除いて、手順の例と同じです:
import javax.ws.rs.GET;
import javax.ws.rs.Path;
import javax.ws.rs.Produces;
import javax.ws.rs.core.MediaType;
// Plain old Java Object it does not extend as class or implements
// an interface
// The class registers its methods for the HTTP GET request using the @GET annotation.
// Using the @Produces annotation, it defines that it can deliver several MIME types,
// text, XML and HTML.
// The browser requests per default the HTML MIME type.
//Sets the path to base URL + /hello
@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> ";
}
}
私はこの問題に何度も苦労しました。
現在使用しているソリューションは、webapp(またはjspのようなビューを保持しているフォルダー)がDeployment Assemblyの下にあることです。
これを行うには、project > Build Path > Configure Build path > Deployment Assembly > Add(right hand side) > Folder > (add your jsp folder. In default case it is src/main/webapp)
を右クリックします
各メソッドはパスを指定する必要があります
このような :
@GET
@Path("testOne")
@Produces(MediaType.TEXT_HTML)