java springboot 实现 对象或对象数组 转为 前端可解析的JSON字符串格式

这是我的接口代码

逻辑就是 通过 IBookService对象中的 list 函数获取数据列表

然后定义 state(响应状态) message(提示信息)

最后将这三个信息 做成对象返回给前端

接口访问结果

但是这种对象数组对存储空间消耗肯定是比字符串大很多的

所以 我们来尝试 将json数组转成字符串内容返回

我们先要注入依赖

xml 复制代码
<dependency>
    <groupId>com.fasterxml.jackson.core</groupId>
    <artifactId>jackson-core</artifactId>
    <version>2.12.3</version>
</dependency>

<dependency>
    <groupId>com.fasterxml.jackson.core</groupId>
    <artifactId>jackson-databind</artifactId>
    <version>2.12.3</version>
</dependency>

然后 我们在需要使用的类中导包

java 复制代码
import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.core.JsonProcessingException;

然后 我们直接将代码改成这样

java 复制代码
@GetMapping
public ResultUtil getAll() {
    List<book> BookList = IBookService.list();
    int state = BookList.isEmpty() ? 500 : 200;
    String message = BookList.isEmpty() ? "未获取到对应记录" : "操作成功";
    try {
        ObjectMapper objectMapper = new ObjectMapper();
        String json = objectMapper.writeValueAsString(BookList);
        return new ResultUtil(state, json, message);
    } catch (JsonProcessingException e) {
        e.printStackTrace();
        // 处理异常情况
        return new ResultUtil(500, null, "JSON转换错误");
    }
}

简单说转换的代码就是

javascript 复制代码
try {
    ObjectMapper objectMapper = new ObjectMapper();
    String json = objectMapper.writeValueAsString(需要转字符串的 对象/对象数组);
} catch (JsonProcessingException e) {
    e.printStackTrace();
    // 处理异常情况
}

我们重新运行项目 访问接口

空口无凭 我们用前端调用试一下

运行结果如下

相关推荐
k***85842 小时前
SpringBoot(整合MyBatis + MyBatis-Plus + MyBatisX插件使用)
spring boot·tomcat·mybatis
喵个咪2 小时前
Qt 6 实战:C++ 调用 QML 回调方法(异步场景完整实现)
前端·c++·qt
F***c3253 小时前
React自然语言处理应用
前端·react.js·自然语言处理
1***Q7843 小时前
React项目
前端·javascript·react.js
幸福专买店3 小时前
【Flutter】flutter 中 包裹内容显示 的设置方式
前端·javascript·flutter
q***44813 小时前
Spring Boot 中 RabbitMQ 的使用
spring boot·rabbitmq·java-rabbitmq
百***06013 小时前
五大消息模型介绍(RabbitMQ 详细注释版)
java·rabbitmq·java-rabbitmq
q***48413 小时前
SpringBoot实战(三十二)集成 ofdrw,实现 PDF 和 OFD 的转换、SM2 签署OFD
spring boot·后端·pdf
和和和4 小时前
🗣️面试官: 那些常见的前端面试场景问题
前端·javascript·面试
lxp1997414 小时前
vue笔记摘要-更新中
前端·vue.js·笔记