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

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

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

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

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

实体类:

java 复制代码
@Data
@NoArgsConstructor
@AllArgsConstructor
public class User {
    private String name;
    private Integer age;
    private String gender;
}

请求体数据

java 复制代码
{"name":"z","age":"3","gender":"男"}

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

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

java 复制代码
@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集合:

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

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

java 复制代码
[{"name":"z","age":4},{"name":"zz","age":5},{"name":"zzz","age":6}]

方法定义:

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

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

java 复制代码
{   
"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博客

相关推荐
oioihoii几秒前
C++11标准库算法:深入理解std::none_of
java·c++·算法
老虎062719 分钟前
数据结构(Java)--位运算
java·开发语言·数据结构
yanjiaweiya20 分钟前
云原生-集群管理续
java·开发语言·云原生
写不出来就跑路26 分钟前
暑期实习感悟与经验分享:从校园到职场的成长之路
java·开发语言·经验分享·spring boot
泰勒疯狂展开30 分钟前
Java研学-MongoDB(二)
java·mongodb
程序员张34 小时前
Maven编译和打包插件
java·spring boot·maven
ybq195133454315 小时前
Redis-主从复制-分布式系统
java·数据库·redis
weixin_472339466 小时前
高效处理大体积Excel文件的Java技术方案解析
java·开发语言·excel