Jersey+Spring+Maven(转)

spring和maven的搭建参考相关文档。本文只介绍与jersey有关配置。

一、jersey在maven中的依赖包

  • <!-- jersey -->

    <dependency>

        <groupId>com.sun.jersey</groupId>
        <artifactId>jersey-core</artifactId>
        <version>1.8</version>

      </dependency>

       <dependency> 

        <groupId>com.sun.jersey</groupId>
        <artifactId>jersey-server</artifactId>
        <version>1.8</version>

      </dependency>

      <dependency> 

        <groupId>com.sun.jersey</groupId>
        <artifactId>jersey-client</artifactId>
        <version>1.8</version>

      </dependency>

      <dependency> 

       <groupId>javax.ws.rs</groupId>
         <artifactId>javax.ws.rs-api</artifactId>
         <version>2.0-m10</version>

      </dependency>

      <dependency> 

        <groupId>javax.ws.rs</groupId>
        <artifactId>jsr311-api</artifactId>
        <version>1.1.1</version>

      </dependency>

    <dependency> 

        <groupId>asm</groupId>
        <artifactId>asm</artifactId>
        <version>3.3.1</version>

      </dependency>

      <!-- jersey end -->

需要json,加入以下

<!--  json-->

<dependency>

   <groupId>com.sun.jersey</groupId>

   <artifactId>jersey-json</artifactId>

   <version>1.8</version>

</dependency>

<dependency>

   <groupId>org.codehaus.jackson</groupId>

   <artifactId>jackson-mapper-asl</artifactId>

   <version>1.8.8</version>

</dependency>

  <!--  json-->

尽量保持包版本的一致

二、整合spring

 

1、 引入整合包,注意版本

<!-- jersey spring -->

<dependency>

            <groupId>com.sun.jersey.contribs</groupId>

            <artifactId>jersey-spring</artifactId>

            <version>1.8</version>

            <!-- 去除自带的spring版本 -->

            <exclusions>

                <exclusion>

                    <groupId>org.springframework</groupId>

                    <artifactId>spring-aop</artifactId>

                </exclusion>

                <exclusion>

                    <groupId>org.springframework</groupId>

                    <artifactId>spring-context</artifactId>

                </exclusion>

                <exclusion>

                    <groupId>org.springframework</groupId>

                    <artifactId>spring-beans</artifactId>

                </exclusion>

                <exclusion>

                    <groupId>org.springframework</groupId>

                    <artifactId>spring-core</artifactId>

                </exclusion>

                <exclusion>

                    <artifactId>spring-web</artifactId>

                    <groupId>org.springframework</groupId>

                </exclusion>

            </exclusions>

        </dependency>

   <!-- jersey spring end-->

   2、web.xml配置

所有rest请求都经过spring过滤

<!-- jersey spring -->
<dependency>
<groupId>com.sun.jersey.contribs</groupId>
<artifactId>jersey-spring</artifactId>
<version>1.8</version>
<!-- 去除自带的spring版本 -->
<exclusions>
<exclusion>
<groupId>org.springframework</groupId>
<artifactId>spring-aop</artifactId>
</exclusion>
<exclusion>
<groupId>org.springframework</groupId>
<artifactId>spring-context</artifactId>
</exclusion>
<exclusion>
<groupId>org.springframework</groupId>
<artifactId>spring-beans</artifactId>
</exclusion>
<exclusion>
<groupId>org.springframework</groupId>
<artifactId>spring-core</artifactId>
</exclusion>
<exclusion>
<artifactId>spring-web</artifactId>
<groupId>org.springframework</groupId>
</exclusion>
</exclusions>
</dependency>
<!-- jersey spring end-->
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>3.8.1</version>
<scope>test</scope>
</dependency>
 
三、编写服务端资源
 

import javax.xml.bind.annotation.XmlRootElement;

@XmlRootElement

public class User  implements java.io.Serializable{

  private static final long serialVersionUID = 1L;  

     private String userName = "";  

     private int age = 0;  

     public String getUserName() {  

         return userName;  

     }  

     public void setUserName(String userName) {  

         this.userName = userName;  

     }  

     public int getAge() {  

         return age;  

     }  

     public void setAge(int age) {  

         this.age = age;  

     }

     public String toString() {

      return "name:"+ userName + " age:" + age;

     }

}

import javax.ws.rs.FormParam;

import javax.xml.bind.annotation.XmlRootElement;

@XmlRootElement //表示可以被转换为xml或json格式

public class Home   implements java.io.Serializable {

@FormParam("roomno")

private int roomNo;

@FormParam("address")

private String address;

private String longtime;

public int getRoomNo() {

  return roomNo;

}

public void setRoomNo(int roomNo) {

  this.roomNo = roomNo;

}

public String getAddress() {

  return address;

}

public void setAddress(String address) {

  this.address = address;

}

public String getLongtime() {

  return longtime;

}

public void setLongtime(String longtime) {

  this.longtime = longtime;

}

public String toString() {

  return "roomNo:" + roomNo + "  address:" + address + "  longtime:" + longtime;

}

}

2、编写资源接口

import javax.ws.rs.BeanParam;

import javax.ws.rs.Consumes;

import javax.ws.rs.FormParam;

import javax.ws.rs.GET;

import javax.ws.rs.POST;

import javax.ws.rs.Path;

import javax.ws.rs.PathParam;

import javax.ws.rs.Produces;

import javax.ws.rs.QueryParam;

import javax.ws.rs.core.MediaType;

@Component         //定义此类为spring组件,即bean类.

@Scope("prototype")   //Spring会针对每一个request请求都生成新的Jersey服务类实例,此方法不需要配置Spring RequsetContextListener

@Path("/restresource")

public class TestRestResource {

1、无参数返回json格式,如返回xml,将Produces参数修改为MediaType.APPLICATION_XML

@GET

@Path("/getUser")

@Produces(MediaType.APPLICATION_JSON)

public User getUser() {  

         User user = new User();  

         user.setUserName("sed");  

         user.setAge(29);  

         return user;  

   }

2、@PathParam("id")获取URI中指定规则的参数

@GET

@Path("getUser/{id}")

@Produces(MediaType.TEXT_PLAIN)

public String getUserId(@PathParam("id") String id) {

      return id; 

}

3、@QueryParam 用于获取GET请求中的查询参数

@GET  

    @Path("getId")  

    @Produces(MediaType.TEXT_PLAIN)  

    public String getId(@QueryParam("id") String id)  

    {  

        return id;  

    }

4、输入参数为xml格式,输出为json格式。可以根据需要切换produces和consumes的类型

@POST

@Path("insertUser")

@Produces(MediaType.APPLICATION_JSON)  //指定发送请求的 MIME 类型

@Consumes(MediaType.APPLICATION_XML)  //指定响应所能接受的 MIME 类型

public User insertuser(User user) {

     return user; 

}

5、BeanParam 当请求参数很多时,比如客户端提交一个修改用户的PUT请求,请求中包含很多项用户信息

@PUT

@Path("insertUserFromBean")

@Consumes(MediaType.APPLICATION_JSON)

@Produces(MediaType.APPLICATION_JSON)

public User inserthome(@BeanParam User user) {

return user;

}

6、@FormParam 从POST请求的表单参数中获取数据

@POST

@Path("insertUserFromForm")

@Consumes("application/x-www-form-urlencoded")

@Produces(MediaType.TEXT_PLAIN)  

public String insertuser(@FormParam("username") String userName, @FormParam("age") int age) {

  User user = new User();

  user.setUserName(userName);

  user.setAge(age);

  return user.toString();

}

7、多参数传递

@POST

@Path("map")

@Produces(MediaType.TEXT_PLAIN)

public String getMap(MultivaluedMap<String, String>  formParams) {

  String result = "who:" + formParams.getFirst("who") + " ; what:"+formParams.getFirst("what");

     return formParams.toString();

}

8、

@DELETE

@Path("deleteUser/{id}")

@Produces(MediaType.TEXT_PLAIN)

public String deleteUser(@PathParam("id") String id) {

  //System.out.println(uriInfo.getAbsolutePath().toString());

  return "delete " + id;

}

}

四、客户端调用

private static WebResource getWr(String USER_URL)  {

             Client c = Client.create();  //创建一个 com.sun.jersey .api.client.Client 类的实例

     WebResource wr = c.resource(USER_URL);  // 建了一个 WebResponse 对象

     return wr;

    }

1、调用getUser

代码:

String USER_URL = "http://localhost:8000/restful/services/restresource/getUser";

System.out.println(getWr(USER_URL).get(String.class));

输出:

{"userName":"sed","age":29}

2、调用getUser/{id}

代码:

String USER_URL = "http://localhost:8000/restful/services/restresource/getUser";

String result = getWr(USER_URL).path("hnsed").get(String.class) ;

System.out.println(result);

输出:

hnsed

3、调用getId

代码:

String USER_URL = "http://localhost:8000/restful/services/restresource/getId";

String result = getWr(USER_URL).queryParam("id", "109").get(String.class);

System.out.println(result);

输出:

109

4、调用insertUser

代码:

User user = new User();
user.setUserName("hndes");
user.setAge(39);
String USER_URL = "http://localhost:8000/restful/services/restresource/insertUser";
MultivaluedMapImpl params = new MultivaluedMapImpl();
params.add("user", user);
String result = getWr(USER_URL).entity(user,MediaType.APPLICATION_XML).post(String.class);
System.out.println(result);
输出:
{"userName":"hndes","age":39}
5、调用insertUserFromBean
代码:
String USER_URL = "http://localhost:8000/restful/services/restresource/insertUserFromBean";
String json = "{"userName":"szh","age":"6"}";
System.out.println(getWr(USER_URL).entity(json,MediaType.APPLICATION_JSON).put(String.class));
输出:
{"userName":"szh","age":6}

6、调用insertUserFromForm

代码:

String USER_URL = "http://localhost:8000/restful/services/restresource/insertUserFromForm";

Form form = new Form();

form.add("username", "sed");

form.add("age",39);

//ClientResponse 对象代表了一个客户端收到的 HTTP 响应。

ClientResponse response = getWr(USER_URL).type(MediaType.APPLICATION_FORM_URLENCODED).post(ClientResponse.class, form);

int status = response.getStatus();   //获取对应请求的 HTTP 状态码

System.out.println(response.getEntity(String.class));

输出:

name:sed age:39

7、调用map

代码:

MultivaluedMap<String, String> params = new MultivaluedMapImpl();

params.add("who", "sed");

params.add("what","dohousework");

params.add("how","good");

params.add("where","hk");

params.add("when","long time");

String USER_URL = "http://localhost:8000/restful/services/restresource/map";

String result = getWr(USER_URL).post(String.class,params);

System.out.println(result);

输出:

{what=[dohousework], how=[good], when=[long time], where=[hk], who=[sed]}

8、调用deleteUser

代码:

String USER_URL = "http://localhost:8000/restful/services/restresource/deleteUser";

String result = getWr(USER_URL).path("109").delete(String.class);

System.out.println(result);

输出:

delete 109

注:1、Client 类是创建一个 RESTful Web Service 客户端的主要配置点。你可以使用它来配置不同的客户端属性和功能,并且指出使用哪个资源提供者。创建一个 Client 类的实例是一个比较昂贵的操作,所以尽量避免创建一些不需要的客户端实例。比较好的方式是尽可能地复用已经存在的实例。

2、通过使用 WebResource 对象来创建要发送到 Web 资源的请求,以及处理从 Web 资源返回的响应。例如,你可以使用 WebResource 对象来发送 HTTP GET、PUT、POST 以及 DELETE 请求

FireShot Capture 1 - jersey spring _ - http___ekekyn.blog.163.com_blog_static_313887320151294452322_ 

 

FireShot Capture 2 - jersey spring _ - http___ekekyn.blog.163.com_blog_static_313887320151294452322_

转载地址:http://ekekyn.blog.163.com/blog/static/313887320151294452322/

原文地址:https://www.cnblogs.com/xu-xiang/p/5851619.html