基于jersey和Apache Tomcat构建Restful Web服务(二)html
上篇博客介绍了REST以及Jersey并使用其搭建了一个简单的“Hello World”,那么本次呢,再来点有趣的东西,固然也是很简单了,仅仅是在路径中包含参数而已了。接下来开始动手实践吧。java
在路径中包含参数json
接下来就在上次的基础上进行改动便可,或者是再添加一个方法,随意了,这个方法主要就是在路径中加入输入的参数,而且根据参数的不一样,它的返回值也不一样,返回值为“Hello”+你输入的参数。这里用到了“PathParam”这个参数,具体代码以下: app
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格式的数据呢?this
使用POJO和List来使结果返回Json格式 spa
上面仅仅是简单的字符串返回值,有够无聊的,下面再来点更有趣的:.net
首先,你须要在WEB-INF的lib下加入一个用于处理Json的jar包,而后你须要建立一个People的POJO,个人POJO以下:code
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。htm
接下来在你的类中加入方法:
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
<。)#)))≦