@RequestBody详解:用于获取请求体中的Json格式参数

获取请求体中的Json格式参数 (@RequestBody)

当前端将一些比较复杂的参数转换成Json字符串通过请求体传递过来给后端,这种时候就可以使用@RequestBody注解获取请求体中的数据。

而json字符串是包含在请求体中的,使用请求体传参通常都是使用POST请求

SpringBoot的web启动器已经默认导入了jackson的依赖,不需要再额外导入依赖了。

实体类:

@Data
@NoArgsConstructor
@AllArgsConstructor
public class User {
    private String name;
    private Integer age;
    private String gender;
}

请求体数据

{"name":"z","age":"3","gender":"男"}

1.获取前端传的参数封装成实体对象

如下把Json数据获取出来封装User对象

@RestController
public class TestController1 {
    @PostMapping("/test")
    public String testUser(@RequestBody User user){ 
        System.out.println(user);
        return user.toString();
    }
}

打印了获取到的 User 对象,它会输出类似于 User(name=z, age=3, gender=男)

2.获取参数封装成Map集合

也可以把该数据获取出来封装成Map集合:

   
 @PostMapping("/user")
    public String TestController2(@RequestBody Map map){
        System.out.println(map);
        return "Test2";
    }

如果请求体传递过来的数据是一个User集合转换成的json,Json数据可以这样定义:

[{"name":"z","age":4},{"name":"zz","age":5},{"name":"zzz","age":6}]

方法定义:

   
 @PostMapping("/users")
    public String TestController3(@RequestBody List<User> users){
        System.out.println(users);
        return "test3";
    }

假如是复杂对象,按照上面json定义方式结合在一起写即可:

{   
"id":1,
"Users":
    [{"name":"z","age":4},{"name":"zz","age":5},{"name":"zzz","age":6}],
"score":["100","0","99"]
}

  如果需要使用@RequestBody来获取请求体中Json并且进行转换,要求请求头 Content-Type 的值要为: application/json 。也就是前端以Content-Type 为application/json,传递json字符串数据,后端以@RequestBody 模型接收数据。

——————————————————————————————————————————

其他Controller类常用的注解可以这个文章的汇总:Web开发Controller类详解-CSDN博客

  • 16
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
@RequestBody和@PathVariable是Spring框架中用于处理HTTP请求的注解,它们有一些区别。 @RequestBody注解是用来接收前端传递给后端请求体中的数据,通常用于接收JSON或XML等类型的数据。它主要用于POST请求,因为GET请求没有请求体,所以无法接收参数。通过@RequestBody注解,后端可以将请求体中的数据与方法的入参绑定起来,方便获取和处理。例如,@PostMapping注解中使用@RequestBody注解来接收请求体中的数据。 @PathVariable注解用于从URL路径中获取占位符的值。一般用于GET请求,通过URL中的{xxx}占位符,可以使用@PathVariable注解将其值绑定到方法的入参上。例如,@GetMapping注解中使用@PathVariable注解来获取路径中的参数值。 因此,@RequestBody注解主要用来接收请求体中的数据,而@PathVariable注解主要用来获取URL路径中的参数值。它们在用途和应用场景上有所不同。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [@RequestParam @RequestBody @PathVariable用法详解](https://blog.csdn.net/weixin_53690059/article/details/126304538)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值