Spring MVC 教程-返回json格式数据&通用返回值设计

作者简介:大家好,我是smart哥,前中兴通讯、美团架构师,现某互联网公司CTO

联系qq:184480602,加我进群,大家一起学习,一起进步,一起对抗互联网寒冬

学习必须往深处挖,挖的越深,基础越扎实!

阶段1、深入多线程

阶段2、深入多线程设计模式

阶段3、深入juc源码解析


阶段4、深入jdk其余源码解析


阶段5、深入jvm源码解析

码哥源码部分

码哥讲源码-原理源码篇【2024年最新大厂关于线程池使用的场景题】

码哥讲源码【炸雷啦!炸雷啦!黄光头他终于跑路啦!】

码哥讲源码-【jvm课程前置知识及c/c++调试环境搭建】

​​​​​​码哥讲源码-原理源码篇【揭秘join方法的唤醒本质上决定于jvm的底层析构函数】

码哥源码-原理源码篇【Doug Lea为什么要将成员变量赋值给局部变量后再操作?】

码哥讲源码【你水不是你的错,但是你胡说八道就是你不对了!】

码哥讲源码【谁再说Spring不支持多线程事务,你给我抽他!】

终结B站没人能讲清楚红黑树的历史,不服等你来踢馆!

打脸系列【020-3小时讲解MESI协议和volatile之间的关系,那些将x86下的验证结果当作最终结果的水货们请闭嘴】

目前比较流行前后端分离,后端只需为前端提供restfull接口,所有的接口都返回json格式的数据,前端接收到json数据之后再进行处理。

那么在SpringMVC中如何向前端输出json格式的数据呢?

常见的有3种方式,我们来了解下。

1、方式1:方法上添加@ResponseBody

需求

使用springmvc提供一个接口,以json格式输出用户列表。

3个步骤

step1:maven配置引入jackjson

jackjson用于将java对象转换为json格式的字符串,也可以将json格式的字符串转换为java对象

我们的接口需要将java对象转换为json格式的字符串输出到客户端,所以我们需要用到这个包。

     <!-- 添加jackson配置 -->
    <dependency>
        <groupId>com.fasterxml.jackson.core</groupId>
        <artifactId>jackson-core</artifactId>
        <version>2.11.4</version>
    </dependency>
    
    <dependency>
        <groupId>com.fasterxml.jackson.core</groupId>
        <artifactId>jackson-databind</artifactId>
        <version>2.11.4</version>
    </dependency>

step2:springmvc配置文件中添加注解驱动
    <!-- 添加mvc注解驱动 -->
    <mvc:annotation-driven/>

添加了这段代码之后,springmvc就被赋予了将java对象转换为json格式字符串输出到客户端的能力。

step3:处理器的方法上添加@ResponseBody注解

如下代码,我们希望list()方法用于向客户端以json格式输出用户列表。

此时只需要在这个方法上面添加一个@ResponseBody注解,SpringMVC发现这个方法上有@ResponseBody这个注解,并且方法返回值是一个普通的java对象的时候,会将方法的返回值使用jackson转换为json格式的字符串,然后输出到客户端。

    @Controller
    public class UserController {
        /**
         * 用户列表(用户id->用户信息)
         */
        Map<Long, UserDto> userDtoMap = new ConcurrentHashMap<>();
    
        {
            userDtoMap.put(1L, new UserDto(1L, "路人", 30));
            userDtoMap.put(2L, new UserDto(2L, "张三", 20));
            userDtoMap.put(3L, new UserDto(3L, "李四", 18));
        }
    
        @GetMapping("/user/list.do")
        @ResponseBody
        public Collection<UserDto> list() {
            return this.userDtoMap.values();
        }
    
    }

验证效果

谷歌浏览器中访问下这个接口

F12看一下接口的响应头,如下,可以看到response的Content-Type的值为application/json;chatset=UTF-8,这个说明响应结果的内容格式是json格式。

2、方式2:Controller上添加@ResponseBody注解

当我们controller中方法很多的时候,且所有方法都要求返回json格式的数据的时候,如果按照方式1,我们需要在每个方法上都要添加@ResponseBody注解,此时有更简单的方法,将所有方法上的@ResponseBody注解都去掉,然后在Controller上加上@ResponseBody就可以了。

比如下面这段代码,我们可以将2个方法上面的@ResponseBody干掉,然后在类上添加@ResponseBody注解就可以了。

    @Controller
    public class UserController {
    
        Map<Long, UserDto> userDtoMap = new ConcurrentHashMap<>();
    
        {
            userDtoMap.put(1L, new UserDto(1L, "路人", 30));
            userDtoMap.put(2L, new UserDto(2L, "张三", 20));
            userDtoMap.put(3L, new UserDto(3L, "李四", 18));
        }
    
        @GetMapping("/user/list.do")
        @ResponseBody
        public Collection<UserDto> list() {
            return this.userDtoMap.values();
        }
    
    
        @GetMapping("/user/{id}.do")
        @ResponseBody
        public UserDto user(@PathVariable("id") Long id) {
            return this.userDtoMap.get(id);
        }
    
    }

调整之后如下

    @Controller
    @ResponseBody
    public class UserController {
    
        Map<Long, UserDto> userDtoMap = new ConcurrentHashMap<>();
    
        {
            userDtoMap.put(1L, new UserDto(1L, "路人", 30));
            userDtoMap.put(2L, new UserDto(2L, "张三", 20));
            userDtoMap.put(3L, new UserDto(3L, "李四", 18));
        }
    
        @GetMapping("/user/list.do")
        public Collection<UserDto> list() {
            return this.userDtoMap.values();
        }
    
    
        @GetMapping("/user/{id}.do")
        public UserDto user(@PathVariable("id") Long id) {
            return this.userDtoMap.get(id);
        }
    
    }

3、方式3:Controllers上使用@RestController

我们回头再看下上面代码,如下图,UserController上有2个注解@Controller@ResponseBody,而SpringMVC提供了一个更好的注解@RestController,相当于这2个注解的合体,所以可以用来替换这2个注解。

4、restfull接口通用返回值

客户端调用服务器端接口的时候,接口有可能会发生异常,这些异常信息需要返回给调用者,通常我们会为错误定义错误码以及提示信息。

一般我们会定义通用的返回值类型,格式如下:

    /**
     * rest接口通用返回值数据结构
     * @param <T>
     */
    public class ResultDto<T> {
        //接口状态(成功还是失败)
        private Boolean success;
        //错误码
        private String code;
        //提示信息
        private String msg;
        //数据
        private T data;
    
        public static <T> ResultDto<T> success(T data) {
            return success(data, "操作成功!");
        }
    
        public static <T> ResultDto<T> success(T data, String msg) {
            ResultDto<T> result = new ResultDto<>();
            result.setSuccess(Boolean.TRUE);
            result.setMsg(msg);
            result.setData(data);
            return result;
        }
    
        //省略get、set方法
    	
    }

控制器中所有的方法都返回ResultDto类型的结果,如下代码

    @RestController
    public class UserController {
    
        Map<Long, UserDto> userDtoMap = new ConcurrentHashMap<>();
    
        {
            userDtoMap.put(1L, new UserDto(1L, "路人", 30));
            userDtoMap.put(2L, new UserDto(2L, "张三", 20));
            userDtoMap.put(3L, new UserDto(3L, "李四", 18));
        }
    
        @GetMapping("/user/list.do")
        public ResultDto<Collection<UserDto>> list() {
            return ResultDto.success(this.userDtoMap.values());
        }
    
    
        @GetMapping("/user/{id}.do")
        public ResultDto<UserDto> user(@PathVariable("id") Long id) {
            return ResultDto.success(this.userDtoMap.get(id));
        }
    
    }

5、案例代码

    git地址:https://gitee.com/javacode2018/springmvc-series

6、总结

  • 掌握@ResponseBody的用法,用来返回json格式的数据,注意需要在springmvc配置文件中添加注解驱动的配置,否则调用会报错
        <!-- 添加mvc注解驱动 -->
        <mvc:annotation-driven/>
  • 掌握通用接口返回值的用法
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值