基于jersey和Apache Tomcat构建Restful Web服务(二)
上篇博客介绍了REST以及Jersey并使用其搭建了一个简单的“Hello World”,那么本次呢,再来点有趣的东西,当然也是很简单了,仅仅是在路径中包含参数而已了。接下来开始动手实践吧。
在路径中包含参数
接下来就在上次的基础上进行改动即可,或者是再添加一个方法,随意了,这个方法主要就是在路径中加入输入的参数,并且根据参数的不同,它的返回值也不同,返回值为“Hello”+你输入的参数。这里用到了“PathParam”这个参数,具体代码如下:
1 @GET 2 @Path("/{username}") 3 @Produces(MediaType.TEXT_PLAIN) 4 public String getHello(@PathParam("username") String userName) { 5 System.out.println(userName); 6 return "Hello "+userName; 7 }
这次使用Firefox提供的RESTClient来测试,输入路径后结果如下:
怎么样,很不错吧。但是貌似字符串用的不多欸,有木有,一般都是返回的Json格式的数据。那么如何让它返回Json格式的数据呢?
使用POJO和List来使结果返回Json格式
上面仅仅是简单的字符串返回值,有够无聊的,下面再来点更有趣的:
首先,你需要在WEB-INF的lib下加入一个用于处理Json的jar包,然后你需要创建一个People的POJO,我的POJO如下:
1 @XmlRootElement 2 public class People { 3 4 private String name; 5 private String password; 6 7 public String getName() { 8 return name; 9 } 10 public void setName(String name) { 11 this.name = name; 12 } 13 public String getPassword() { 14 return password; 15 } 16 public void setPassword(String password) { 17 this.password = password; 18 }
此方法仅仅包含简单的set/get方法。当然了,不要忘了对此类加Jersey的注解:@XmlRootElement。
接下来在你的类中加入方法:
1 @GET 2 @Produces("application/json") 3 @Consumes("application/json") 4 public List<People> getPass(){ 5 6 List<People> list = new ArrayList<People>(); 7 People people = new People(); 8 for (int i = 0; i < 6; i++) { 9 10 people.setName("Li"+i); 11 people.setPassword("123456"+i); 12 list.add(people); 13 } 14 return list; 15 }
好了,接下来就是测试了,和前面一样,输入路径,将显示如下结果:
其他的诸如POST、PUT、DELETE方法与此类似,不再一一示范。
欲了解更多,请参考以下资料:https://jersey.java.net/documentation/latest/getting-started.html#new-from-archetype
PS:本博客欢迎转发,但请注明博客地址及作者,因本人水平有限,若有不对之处,欢迎指出,谢谢~
博客地址:http://www.cnblogs.com/voidy/
博客新址:http://voidy.net
<。)#)))≦