微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

webservice里的@queryparam、@pathparam、@DefaultValue使用介绍

1 先来看@queryparam
   先看例子:
 
Path("/users") 
public class UserService { 
  
    @GET 
    @Path("/query") 
    public Response getUsers( 
        @QueryParam("from") int from,@QueryParam("to") int to,@QueryParam("orderBy") List<String> orderBy) { 
  
        return Response 
           .status(200) 
           .entity("getUsers is called,from : " + from + ",to : " + to 
            + ",orderBy" + orderBy.toString()).build(); 
  
    } 
  
} 

 URL输入为:

users/query?from=100&to=200&orderBy=age&orderBy=name
  此时,输出为:
getUsers is called,from : 100,to : 200,orderBy[age,name]
   要注意的是,跟@pathparam不同,@queryparam
中,指定的是URL中的参数是以键值对的形式出现的,而在程序中
@QueryParam("from") int from则读出URL中from的值,
而@pathparem中,URL中只出现参数的值,不出现键值对,比如:
“/users/2011/06/30”

则:
@GET 
    @Path("{year}/{month}/{day}") 
    public Response getUserHistory( 
            @PathParam("year") int year,@PathParam("month") int month,@PathParam("day") int day) { 
  
       String date = year + "/" + month + "/" + day; 
  
       return Response.status(200) 
        .entity("getUserHistory is called,year/month/day : " + date) 
        .build(); 
  
    } 
输出为:
getUserHistory is called,year/month/day : 2011/6/30
2 以动态的方式获得:

@Path("/users") 
public class UserService { 
  
    @GET 
    @Path("/query") 
    public Response getUsers(UriInfo info) { 
  
        String from = info.getQueryParameters().getFirst("from"); 
        String to = info.getQueryParameters().getFirst("to"); 
        List<String> orderBy = info.getQueryParameters().get("orderBy"); 
  
        return Response 
           .status(200) 
           .entity("getUsers is called,orderBy" + orderBy.toString()).build(); 
  
    }
} 
输入为:
URL;users/query?from=100&to=200&orderBy=age&orderBy=name
输出为:
getUsersis called,name]
注意这里把orderby后的两个参数读入为LIST处理了.

3 @DefaultValue,认值

  例子:

@Path("/users") 
public class UserService { 
  
    @GET 
    @Path("/query") 
    public Response getUsers( 
        @DefaultValue("1000")@QueryParam("from") int from,@DefaultValue("999")@QueryParam("to") int to,@DefaultValue("name")@QueryParam("orderBy") List<String> orderBy) { 
  
        return Response 
           .status(200) 
          .entity("getUsers is called,to : " +to 
            + ",orderBy" + orderBy.toString()).build(); 
  
    } 
输入:
URL:users/query
输出:
getUsers is called,from : 1000,to : 999,orderBy[name]

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。

相关推荐