JAX-RS API提供以下注解可在java中開發RESTful應用程式。 下麵我們將使用 jersey 實現來開發JAX-RS示例。首先打開Eclipse,創建一個動態Web專案:JaxrsWeb。
Jersey Jar檔下載網址:https://jersey.github.io/download.html
1. JAX-RS注釋
javax.ws.rs 包中包含JAX-RS注釋。
注解 | 描述 |
---|---|
Path |
它標識URI路徑,它可以在類或方法上指定。 |
PathParam |
表示URI路徑的參數。 |
GET |
指定方法回應GET請求。 |
POST |
指定方法回應POST請求。 |
PUT |
指定方法回應PUT請求。 |
HEAD |
指定方法回應HEAD請求。 |
DELETE |
指定方法回應DELETE請求。 |
OPTIONS |
指定方法回應OPTIONS請求。 |
FormParam |
表示表單的參數。 |
QueryParam |
表示URL的查詢字串的參數。 |
HeaderParam |
表示標頭的參數。 |
CookieParam |
表示cookie 的參數。 |
Produces |
定義回應的媒體類型,例如:XML ,PLAIN ,JSON 等。它定義資源類或MessageBodyWriter 的方法可以生成的媒體類型。 |
Consumes |
它定義資源類或MessageBodyReader 的方法可以生成的媒體類型。 |
2. JAX-RS @Path, @GET 和 @PathParam 注解
檔:HelloService.java -
package com.zaixian;
import javax.ws.rs.GET;
import javax.ws.rs.Path;
import javax.ws.rs.PathParam;
import javax.ws.rs.core.Response;
@Path("/hello")
public class HelloService{
@GET
@Path("/{param}")
public Response getMsg(@PathParam("param") String msg) {
String output = "Jersey say : " + msg;
return Response.status(200).entity(output).build();
}
}
檔: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">
<servlet>
<servlet-name>Jersey REST Service</servlet-name>
<servlet-class>org.glassfish.jersey.servlet.ServletContainer</servlet-class>
<init-param>
<param-name>jersey.config.server.provider.packages</param-name>
<param-value>com.zaixian</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>
檔:index.html -
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>JAX-RS Server示例</title>
</head>
<body>
<a href="rest/hello/zaixian">JAX-RS注解參數示例</a>
</body>
</html>
現在在伺服器上運行此應用程式,您將看到以下輸出:
3. JAX-RS多個@PathParam
檔:HelloService.java -
package com.zaixian;
import javax.ws.rs.GET;
import javax.ws.rs.Path;
import javax.ws.rs.PathParam;
import javax.ws.rs.core.Response;
@Path("/hello")
public class HelloService{
@GET
@Path("/{param}")
public Response getMsg(@PathParam("param") String msg) {
String output = "Jersey say : " + msg;
return Response.status(200).entity(output).build();
}
@GET
@Path("{year}/{month}/{day}")
public Response getDate(
@PathParam("year") int year,
@PathParam("month") int month,
@PathParam("day") int day) {
String date = year + "/" + month + "/" + day;
return Response.status(200)
.entity("getDate is called, year/month/day : " + date)
.build();
}
}
檔:web.xml 的內容與上面的例子相同。
檔:index.html -
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>JAX-RS Server示例</title>
</head>
<body>
<a href="rest/hello/zaixian">JAX-RS注解參數示例</a><br/>
<a href="rest/hello/2019/12/05">JAX-RS注解參數(日期)示例</a>
</body>
</html>
現在在伺服器上運行此應用程式,您將看到以下輸出:
4. JAX-RS @FormParam和@POST注解
檔: ProductService.java -
package com.zaixian;
import javax.ws.rs.FormParam;
import javax.ws.rs.POST;
import javax.ws.rs.Path;
import javax.ws.rs.core.Response;
@Path("/product")
public class ProductService{
@POST
@Path("/add")
public Response addUser(
@FormParam("id") int id,
@FormParam("name") String name,
@FormParam("price") float price) {
return Response.status(200)
.entity(" Product added successfuly!<br> Id: "+id+"<br> Name: " + name+"<br> Price: "+price)
.build();
}
}
檔:web.xml 的內容與上面的例子相同。
檔:index.html 的內容如下 -
<form action="rest/product/add" method="post">
Enter Id:<input type="text" name="id"/><br/><br/>
Enter Name:<input type="text" name="name"/><br/><br/>
Enter Price:<input type="text" name="price"/><br/><br/>
<input type="submit" value="Add Product"/>
</form>
現在在伺服器上運行此應用程式,您將看到以下輸出:
填寫產品資訊並提交 -
上一篇:
JAX-RS示例(Jersey)
下一篇:
RESTful JAX-RS檔下載示例