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();
    // 处理异常情况
}

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

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

运行结果如下

相关推荐
AI人工智能+电脑小能手7 分钟前
【大白话说Java面试题 第102题】【并发篇】第2题:volatile 能否保证线程安全?
java·安全·面试
KobeSacre13 分钟前
JUC 概述
java·开发语言
程序员黑豆21 分钟前
AI全栈开发之Java:怎么安装JDK
前端·ai编程·全栈
周杰伦fans22 分钟前
AutoCAD C# 二次开发:如何精确监听工作空间切换事件
前端·c#
丷丩37 分钟前
MapLibre GL JS第41课:向地图添加图标
前端·javascript·mapbox·maplibre gl js
小bo波39 分钟前
形式化方法 × UML
java·软件工程·uml·面向对象·形式化方法·tla+
英俊潇洒美少年43 分钟前
前端性能优化:非关键脚本/第三方资源异步加载全解(彻底解决首屏阻塞)
前端·性能优化
就叫_这个吧1 小时前
IDEA中Javaweb项目创建+servlet,实现简单的信息录入获取
java·servlet·intellij-idea·web
程序员Jelena1 小时前
接口调用的代码实现:从入门到实战
java
开飞机的舒克_1 小时前
vue3+router动态权限路由
前端·vue.js