基于jersey和Apache Tomcat构建Restful Web服务(二)

时间:2023-03-09 03:16:05
基于jersey和Apache Tomcat构建Restful Web服务(二)

基于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来测试,输入路径后结果如下:

基于jersey和Apache Tomcat构建Restful Web服务(二)

  怎么样,很不错吧。但是貌似字符串用的不多欸,有木有,一般都是返回的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;
}

  好了,接下来就是测试了,和前面一样,输入路径,将显示如下结果:

基于jersey和Apache Tomcat构建Restful Web服务(二) 

  其他的诸如POST、PUT、DELETE方法与此类似,不再一一示范。

  欲了解更多,请参考以下资料:https://jersey.java.net/documentation/latest/getting-started.html#new-from-archetype

PS:本博客欢迎转发,但请注明博客地址及作者,因本人水平有限,若有不对之处,欢迎指出,谢谢~

  博客地址:http://www.cnblogs.com/voidy/

  博客新址:http://voidy.net

  <。)#)))≦