@RequestMapping @ResponseBody 和 @RequestBody 注解的用法与区别

1、@RequestMapping

@RequestMapping 注解是一个用来处理用户请求映射,可以用于类和方法上。用于类上,表示类中的所有响应请求的方法都会以该地址作为父路径来进行访问;用于方法上,表示在类的路径上追加方法注解的地址就会访问到对应方法。

注意:类上可以不注解@RequestMapping ,但是方法上必须注解

@Controller
//设置类的访问路径
@RequestMapping(value = "/Controllers")
public class StatisticUserCtrl {
  
     // 设置在类的基础上,方法的访问路径
     @RequestMapping(value = "/method")
     public String helloworld() {

          return "helloWorld";

     }
}

类的访问路径:http://localhost:8080/Controllers

方法的访问路径:http://localhost:8080/Controllers/method
 

2、@Responsebody

@Responsebody 注解表示该方法的返回的结果直接写入 HTTP 响应正文(ResponseBody)中,一般在异步获取数据时使用,通常是在使用 @RequestMapping 后,返回值通常解析为跳转路径,加上 @Responsebody 后返回结果不会被解析为跳转路径,而是直接写入HTTP 响应正文中。 

作用: 该注解用于将Controller的方法返回的对象,通过适当的HttpMessageConverter转换为指定格式后,写入到Response对象的body数据区。 
使用时机:返回的数据不是html标签的页面,而是其他某种格式的数据时(如json、xml等)使用

异步获取 json 数据,加上 @Responsebody 注解后,就会直接返回 json 数据。

@Controller
//设置类的访问路径
@ResposeBody
// 将ajax(datas)发出的请求写入 User 对象中,返回json对象响应回去
public class StatisticUserCtrl {
  
     // 设置在类的基础上,方法的访问路径
     @RequestMapping(value = "/method")
     public User helloworld(User user) {
          User user = new User();
          user.setId(1);
          return user;

     }
}

3、@RequestBody

@RequestBody 注解则是将 HTTP 请求正文插入方法中,使用适合的 HttpMessageConverter 将请求体写入某个对象。

作用:

1) 该注解用于读取Request请求的body部分数据,使用系统默认配置的HttpMessageConverter进行解析,然后把相应的数据绑定到要返回的对象上; 
2) 再把HttpMessageConverter返回的对象数据绑定到 controller中方法的参数上

使用:

(1)GET、POST方式提时, 根据request header Content-Type的值来判断:

application/x-www-form-urlencoded, 可选(即非必须,因为这种情况的数据@RequestParam, @ModelAttribute也可以处理,当然@RequestBody也能处理); 
multipart/form-data, 不能处理(即使用@RequestBody不能处理这种格式的数据); 
其他格式, 必须(其他格式包括application/json, application/xml等。这些格式的数据,必须使用@RequestBody来处理)
 

(2)PUT方式提交时, 根据request header Content-Type的值来判断:

application/x-www-form-urlencoded, 必须;multipart/form-data, 不能处理;其他格式, 必须;

注意:request的body部分的数据编码格式由header部分的Content-Type指定;

@RequestMapping(value = "user/login")
@ResponseBody
// 将ajax(datas)发出的请求写入 User 对象中
public User login(@RequestBody User user) {   
    // 这样就不会再被解析为跳转路径,而是直接将user对象写入 HTTP 响应正文中
    return user;    
}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值