本文演示环境为eclipse + Maven插件 + Jersey framework。本文只关注Jersey的使用,所以只使用类中定义的静态数据做演示。请在使用时修改我的代码。如果你的eclipse中没有安装 Maven插件,请关注我的博客,我马上就会推出Maven+eclipse的开发教程。
1. 在eclipse中创建Maven项目
2.单击"Next"
3. 选择Maven项目类型为"maven-archetype-webapp"
4. 输入项目相关的Maven设置
5. 分别创建src/main下java文件夹以及src下test文件夹
6. 设置src/main/java和src/test/java为source folder
7. 最终设置结果如下:
8. 修改pom.xml,添加Maven相应依赖库
< project xmlns ="http://maven.apache.org/POM/4.0.0" xmlns:xsi ="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation ="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd" > < modelVersion > 4.0.0 </ modelVersion > < groupId > net.jianxi.tutorials.jerseyws </ groupId > < artifactId > jerseywstest </ artifactId > < packaging > war </ packaging > < version > 1.0 </ version > < name > jerseywstest Maven Webapp </ name > < url > http://maven.apache.org </ url > < dependencies > < dependency > < groupId > junit </ groupId > < artifactId > junit </ artifactId > < version > 4.7 </ version > < scope > test </ scope > </ dependency > < dependency > < groupId > com.sun.jersey </ groupId > < artifactId > jersey-core </ artifactId > < version > 1.3 </ version > </ dependency > < dependency > < groupId > com.sun.jersey </ groupId > < artifactId > jersey-server </ artifactId > < version > 1.3 </ version > </ dependency > < dependency > < groupId > com.sun.jersey </ groupId > < artifactId > jersey-client </ artifactId > < version > 1.3 </ version > </ dependency > < dependency > < groupId > log4j </ groupId > < artifactId > log4j </ artifactId > < version > 1.2.14 </ 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.2 </ version > </ dependency > </ dependencies > < build > < finalName > jerseywstest </ finalName > < plugins > < plugin > < artifactId > maven-compiler-plugin </ artifactId > < configuration > < source > 1.6 </ source > < target > 1.6 </ target > </ configuration > </ plugin > < plugin > < groupId > org.codehaus.mojo </ groupId > < artifactId > tomcat-maven-plugin </ artifactId > < configuration > < warFile > target/jerseywstest.war </ warFile > </ configuration > </ plugin > </ plugins > </ build > </ project >
9. 添加基本POJO类Student:
1 package net.jianxi.tutorials.jerseyws.metadata; 2 3 import javax.xml.bind.annotation.XmlRootElement; 4 5 @XmlRootElement 6 public class Student { 7 private int id; 8 private String name; 9 private String dept; 10 11 public int getId() { 12 return id; 13 } 14 15 public Student() { 16 } 17 18 public Student( int id, String name, String dept) { 19 super (); 20 this .id = id; 21 this .name = name; 22 this .dept = dept; 23 } 24 public void setId( int id) { 25 this .id = id; 26 } 27 public String getName() { 28 return name; 29 } 30 public void setName(String name) { 31 this .name = name; 32 } 33 public String getDept() { 34 return dept; 35 } 36 public void setDept(String dept) { 37 this .dept = dept; 38 } 39 40 } 41
10. 添加一个REST web服务实现类RestWsDemo:
1 package net.jianxi.tutorials.jerseyws; 2 3 import java.util.ArrayList; 4 import java.util.HashMap; 5 import java.util.List; 6 import java.util.Map; 7 8 import javax.ws.rs.DELETE; 9 import javax.ws.rs.FormParam; 10 import javax.ws.rs.GET; 11 import javax.ws.rs.POST; 12 import javax.ws.rs.PUT; 13 import javax.ws.rs.Path; 14 import javax.ws.rs.PathParam; 15 import javax.ws.rs.Produces; 16 import javax.ws.rs.QueryParam; 17 import javax.ws.rs.core.MediaType; 18 19 import net.jianxi.tutorials.jerseyws.metadata.Student; 20 21 import org.apache.log4j.Logger; 22 23 24 @Path( " /students " ) 25 public class RestWsDemo { 26 private static Logger logger = Logger.getLogger(RestWsDemo. class ); 27 private static int index = 1 ; 28 private static Map < Integer,Student > studentList = new HashMap < Integer, Student > (); 29 30 public RestWsDemo() { 31 if (studentList.size() == 0 ) { 32 studentList.put(index, new Student(index ++ , " Frank " , " CS " )); 33 studentList.put(index, new Student(index ++ , " Jersey " , " Math " )); 34 } 35 } 36 37 @GET 38 @Path( " {studentid} " ) 39 @Produces({MediaType.APPLICATION_XML, MediaType.APPLICATION_JSON}) 40 public Student getMetadata(@PathParam( " studentid " ) int studentid) { 41 if (studentList.containsKey(studentid)) 42 return studentList.get(studentid); 43 else 44 return new Student( 0 , " Nil " , " Nil " ); 45 } 46 47 @GET 48 @Path( " list " ) 49 @Produces({MediaType.APPLICATION_XML, MediaType.APPLICATION_JSON}) 50 public List < Student > getAllStudents() { 51 List < Student > students = new ArrayList < Student > (); 52 students.addAll(studentList.values()); 53 return students; 54 } 55 56 @POST 57 @Path( " add " ) 58 @Produces( " text/plain " ) 59 public String addStudent(@FormParam( " name " ) String name, 60 @FormParam( " dept " ) String dept) { 61 studentList.put(index, new Student(index ++ , name, dept)); 62 return String.valueOf(index - 1 ); 63 } 64 65 @DELETE 66 @Path( " delete/{studentid} " ) 67 @Produces( " text/plain " ) 68 public String removeStudent(@PathParam( " studentid " ) int studentid) { 69 logger.info( " Receieving quest for deleting student: " + studentid); 70 71 Student removed = studentList.remove(studentid); 72 if (removed == null ) return " failed! " ; 73 else return " true " ; 74 } 75 76 @PUT 77 @Path( " put " ) 78 @Produces( " text/plain " ) 79 public String putStudent(@QueryParam( " studentid " ) int studentid, 80 @QueryParam( " name " ) String name, 81 @QueryParam( " dept " ) String dept 82 ) { 83 logger.info( " Receieving quest for putting student: " + studentid); 84 if ( ! studentList.containsKey(studentid)) 85 return " failed! " ; 86 else 87 studentList.put(studentid, new Student(studentid, name, dept)); 88 89 return String.valueOf(studentid); 90 } 91 } 92
11. 修改src/main/webapp/WEB-INF/web.xml文件如下:
<! DOCTYPE web-app PUBLIC "-//Sun Microsystems, Inc.//DTD Web Application 2.3//EN" "http://java.sun.com/dtd/web-app_2_3.dtd" > < web-app > < display-name > Archetype Created Web Application </ display-name > < servlet > < servlet-name > jerseyws </ servlet-name > < servlet-class > com.sun.jersey.spi.container.servlet.ServletContainer </ servlet-class > < init-param > < param-name > com.sun.jersey.config.property.resourceConfigClass </ param-name > < param-value > com.sun.jersey.api.core.PackagesResourceConfig </ param-value > </ init-param > < init-param > < param-name > com.sun.jersey.config.property.packages </ param-name > < param-value > net.jianxi.tutorials.jerseyws </ param-value > </ init-param > < load-on-startup > 1 </ load-on-startup > </ servlet > < servlet-mapping > < servlet-name > jerseyws </ servlet-name > < url-pattern > /rest/* </ url-pattern > </ servlet-mapping > </ web-app >
12. 运行Maven package任务,构建war文件,部署war应用到你的Web服务器。
13. 测试
我马上就会推出如何用SoapUI工具测试Jersey Web服务的教程。这里这介绍简单的测试方法。
13.1) 对于GET,可以直接通过浏览器进行测试,在浏览器中直接输入:http://localhost:8080/jerseywstest/rest/students/list, 你应该看到返回的XML数据:
输入:http://localhost:8080/jerseywstest/rest/students/1则会返回一个学生的信息。< students > < student > < dept > CS </ dept > < id > 1 </ id > < name > Frank </ name > </ student > < student > < dept > Math </ dept > < id > 2 </ id > < name > Jersey </ name > </ student > </ students >
13.2) 测试POST方法。
添加一个testpost.htm文件
<! DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd" > < html > < head > < meta http-equiv ="Content-Type" content ="text/html; charset=ISO-8859-1" > < title > Insert title here </ title > </ head > < body > < form action ="/jerseywstest/rest/students/add" method ="post" > < input type ="text" id ="name" name ="name" />< br /> < input type ="text" id ="dept" name ="dept" />< br /> < input type = "submit" /> </ form > </ body > </ html >
提交后你在用list方法就可以看到数据的变化。
13.3) PUT和DELETE方法的测试
添加一个Junit测试类
1 package net.jianxi.tutorials.jerseyws; 2 3 4 import javax.ws.rs.core.MultivaluedMap; 5 6 import org.junit.Before; 7 import org.junit.BeforeClass; 8 import org.junit.Test; 9 10 import com.sun.jersey.api.client.Client; 11 import com.sun.jersey.api.client.ClientResponse; 12 import com.sun.jersey.api.client.WebResource; 13 import com.sun.jersey.core.util.MultivaluedMapImpl; 14 15 public class RestWsDemoTest { 16 private String url = " http://localhost:8080/jerseywstest/rest/students " ; 17 18 @Test 19 public void testDelete() { 20 Client client = Client.create(); 21 WebResource webResource = client.resource(url + " /delete/1 " ); 22 ClientResponse response = webResource.delete(ClientResponse. class ); 23 24 System.out.println( " Response for delete request: " + response.getStatus()); 25 } 26 27 @Test 28 public void testPut() { 29 Client client = Client.create(); 30 WebResource webResource = client.resource(url + " /put " ); 31 MultivaluedMap queryParams = new MultivaluedMapImpl(); 32 queryParams.add( " studentid " , " 2 " ); 33 queryParams.add( " name " , " nametest " ); 34 queryParams.add( " dept " , " depttest " ); 35 ClientResponse response = webResource.queryParams(queryParams).put(ClientResponse. class , " foo:test " ); 36 System.out.println( " Response for put request: " + response.getStatus()); 37 } 38 } 39