SpringBoot @ResponseBody、@RequestBody和@RequestParam 基本介绍

本文详细介绍了在 SpringBoot 应用中,@ResponseBody、@RequestBody 和 @RequestParam 这三个注解的用途和工作原理。@ResponseBody 用于将方法返回值以 JSON 格式返回给客户端;@RequestBody 则用于接收 JSON 数据并将其转换为 Java 对象;而 @RequestParam 用于接收请求参数,通常适用于基本数据类型的传递。每个注解的使用场景和注意事项都有所阐述。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

这三个注解主要用于前后端分离架构中 SpringBoot 接收或者传输特定格式数据,现在重新捋一遍。

1、@ResponseBody

位置:注解在方法头上

作用:将方法的返回值以 json/xml 的数据格式返回给客户端,如果是JavaBean对象,调用 getxxx()方法获取属性值,如果是 map集合,调用 get(key)方法获取属性值,然后以键值对的方式转成 json字符串

@GetMapping(value = "/findById")
//注解在方法头上,返回 json/xml
@ResponseBody
public Result findById(@RequestParam Long id) {
    User user = userService.findById(id);
    return ResultUtil.success(user);
}

打印结果如下

image-20201222101727590

没有该注解的影响:将返回一个ModelAndView给客户端,即返回视图,常用的场景是跳转 jsp 页面。

image-20201222102639277

提示没有该页面。

2、@RequestBody

位置:注解在方法的形参前

作用:接收 json/xml封装成 JavaBean 对象或者集合,注意 xml格式的支持需要添加额外的依赖。

@GetMapping(value = "/findById")
@ResponseBody
// 注解在形参前,用于接收 json/xml
public Result findById(@RequestBody User testUser) {
    User user = userService.findById(testUser.getId());
    return ResultUtil.success(user);
}

传参格式如下:

image-20201222104730204

注意点:如果是前端页面传参时,需要手动设置 contentType: "application/json",默认的为 ``application/x-www-form-urlencoded`。

没有该注解的影响:JavaBean 对象或集合将无法接收 json/xml

image-20201222111600126

3、@RequestParam

位置:注解在方法的形参前

作用:用于接收基本数据类型及其包装类。 通过value属性指定传参名称,required属性指定是否必传,默认为必传,defaultValue属性指定默认值。

@GetMapping(value = "/findById")
@ResponseBody
//常用于接收基本数据类型及其包装类
public Result findById(@RequestParam(value = "id", required = true, defaultValue = "2") Long id) {
    User user = userService.findById(id);
    return ResultUtil.success(user);
}

传参格式如下:

image-20201222113451359

注意点:只能使用基本数据类型及其包装类接收数据。

没有该注解的影响:该注解不为必写属性,如果想对参数进行限制可使用。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值