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