javax.​ws.​rs注解:@Conumes 和 @Produces等

转载地址:http://blog.csdn.net/zhengchao1991/article/details/54375626

问:MIME类型是什么? 答:MIME(Multipurpose Internet Mail Extensions)多用途互联网邮件扩展类型。是设定某种扩展名的文件用一种应用程序来打开的方式类型,当该扩展名文件被访问的时候,浏览器会自动使用指定应用程序来打开。

1、概述

@Consumes 注释代表的是一个资源可以接受的 MIME 类型。

@Produces 注释代表的是一个资源可以返回的 MIME 类型。

这些注释均可在资源、资源方法、子资源方法、子资源定位器或子资源内找到。


2、@Produces:返回的类型

a.返回给client字符串类型(text/plain)

  1. @Produces(MediaType.TEXT_PLAIN)   
@Produces(MediaType.TEXT_PLAIN) 

b.返回给client为json类型(application/json)

  1. @Produces(MediaType.APPLICATION_JSON)   
@Produces(MediaType.APPLICATION_JSON) 

测试:

string类型:

  1. @Path(“/say”)    
  2. @GET    
  3. @Produces(MediaType.TEXT_PLAIN)    
  4. public String say() {    
  5.     System.out.println(”hello world”);    
  6.     return “hello world”;       
  7. }    
    @Path("/say")  
    @GET  
    @Produces(MediaType.TEXT_PLAIN)  
    public String say() {  
        System.out.println("hello world");  
        return "hello world";     
    }  

json和bean类型:

  1. @Path(“test”)    
  2. @GET    
  3. @Produces(MediaType.APPLICATION_JSON)    
  4. public Result<String> test() {    
  5.     Result<String> result = new Result<String>();    
  6.     result.success(”aaaaaa”);    
  7.         
  8.     return result;    
  9. }    
  10.     
  11. @Path(“bean”)    
  12. @GET    
  13. @Produces(MediaType.APPLICATION_JSON)    
  14. public UserBean bean() {    
  15.     UserBean userBean = new UserBean();    
  16.     userBean.setId(1);    
  17.     userBean.setUsername(”fengchao”);    
  18.     return userBean;    
  19. }  
    @Path("test")  
    @GET  
    @Produces(MediaType.APPLICATION_JSON)  
    public Result<String> test() {  
        Result<String> result = new Result<String>();  
        result.success("aaaaaa");  

        return result;  
    }  

    @Path("bean")  
    @GET  
    @Produces(MediaType.APPLICATION_JSON)  
    public UserBean bean() {  
        UserBean userBean = new UserBean();  
        userBean.setId(1);  
        userBean.setUsername("fengchao");  
        return userBean;  
    }

3、@Consumes

@Consumes@Produces相反,用来指定可以接受client发送过来的MIME类型,同样可以用于class或者method,也可以指定多个MIME类型,一般用于@PUT,@POST

a.接受client参数为字符串类型

  1.   
@Consumes(MediaType.TEXT_PLAIN)  b.接受clent参数为json类型@Consumes(MediaType.APPLICATION_JSON) 

其他注解:

@PathParam

     获取url中指定参数名称:

  1. @GET    
  2. @Path(“{username”})    
  3. @Produces(MediaType.APPLICATION_JSON)    
  4. public User getUser(@PathParam(“username”) String userName) {    
  5.     …    
  6. }    
@GET  
@Path("{username"})  
@Produces(MediaType.APPLICATION_JSON)  
public User getUser(@PathParam("username") String userName) {  
    ...  
}  

@QueryParam
获取get请求中的查询参数:  
  1. @GET    
  2. @Path(“/user”)    
  3. @Produces(“text/plain”)    
  4. public User getUser(@QueryParam(“name”) String name,    
  5.                      @QueryParam(“age”int age) {    
  6.     …    
  7. }   
@GET  
@Path("/user")  
@Produces("text/plain")  
public User getUser(@QueryParam("name") String name,  
                     @QueryParam("age") int age) {  
    ...  
} 

如果需要为参数设置默认值,可以使用@DefaultValue,如:
  1. @GET    
  2. @Path(“/user”)    
  3. @Produces(“text/plain”)    
  4. public User getUser(@QueryParam(“name”) String name,    
  5.                     @DefaultValue(“26”@QueryParam(“age”int age) {    
  6.     …    
  7. }  
@GET  
@Path("/user")  
@Produces("text/plain")  
public User getUser(@QueryParam("name") String name,  
                    @DefaultValue("26") @QueryParam("age") int age) {  
    ...  
}

@FormParam
 获取post请求中表单中的数据:
  1. @POST    
  2. @Consumes(“application/x-www-form-urlencoded”)    
  3. public void post(@FormParam(“name”) String name) {    
  4.     // Store the message    
  5. }   
@POST  
@Consumes("application/x-www-form-urlencoded")  
public void post(@FormParam("name") String name) {  
    // Store the message  
} 
@BeanParam
 获取请求参数中的数据,用实体Bean进行封装
  1. @POST    
  2. @Consumes(“application/x-www-form-urlencoded”)    
  3. public void update(@BeanParam User user) {    
  4.     // Store the user data    
  5. }    
@POST  
@Consumes("application/x-www-form-urlencoded")  
public void update(@BeanParam User user) {  
    // Store the user data  
}  



  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
您可以按照以下步骤将JAX-WS接口替换为JAX-RS接口: 1. 创建JAX-RS接口:创建一个新的Java接口来定义您的JAX-RS服务。在接口上使用`@Path`注解指定资源的URL路径。 ```java import javax.ws.rs.GET; import javax.ws.rs.Path; import javax.ws.rs.Produces; import javax.ws.rs.core.MediaType; @Path("/your-resource") public interface YourResource { @GET @Produces(MediaType.APPLICATION_JSON) String getResource(); } ``` 2. 实现JAX-RS接口:创建一个类来实现您的JAX-RS接口,并实现接口中定义的方法。 ```java public class YourResourceImpl implements YourResource { @Override public String getResource() { // 实现您的业务逻辑 return "Hello JAX-RS!"; } } ``` 3. 注册JAX-RS服务:将您的JAX-RS服务注册到应用程序中。这可以通过创建一个`javax.ws.rs.core.Application`子类并在其中注册资源类来完成。 ```java import javax.ws.rs.ApplicationPath; import javax.ws.rs.core.Application; import java.util.HashSet; import java.util.Set; @ApplicationPath("/api") public class YourApplication extends Application { @Override public Set<Class<?>> getClasses() { Set<Class<?>> classes = new HashSet<>(); classes.add(YourResourceImpl.class); return classes; } } ``` 4. 配置JAX-RS:根据您使用的应用程序服务器,将JAX-RS的实现(如Jersey或RestEasy)添加到您的应用程序的构建配置文件中。您还需要确保在应用程序服务器上正确配置JAX-RS。 5. 测试JAX-RS接口:启动您的应用程序服务器,并使用JAX-RS客户端或浏览器等工具测试您的JAX-RS接口。 请注意,以上步骤是一般的指导,具体步骤可能因您使用的框架和工具而有所不同。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值