SpringBoot中读取mock数据-高效调试接口

写在前面:故不积跬步,无以致千里,不积小流,无以成江海。

个人感悟:

最近需求上偏向数仓需求较多,大结构型的json或者字符串 比较多,为了节省时间,以往从数据库 或者三方SDK获取数据的地方,直接读取本地mock数据进行调试。真的很高效,无非启动项目,单元测试 或者 主函数就可以自测。 记录一下这次的经验分享给大家,留给自己备用

SpringBoot中读取resource资源文件MOCK数据 调试接口

在 Spring Boot 项目中,通常会将静态资源或配置文件放在 src/main/resources 目录下。以下是如何读取存放在 resources 目录中的文本文件的步骤和代码示例:

文件路径

将文件放在 src/main/resources 目录下,例如文件名为 mock_data.txt

代码示例

可以通过 Spring 的 ClassPathResource 或标准的 ClassLoader 来读取 resources 中的文件内容。

方法 1:使用 ClassPathResource
java 复制代码
import org.springframework.core.io.ClassPathResource;
import java.io.BufferedReader;
import java.io.InputStreamReader;
import java.nio.charset.StandardCharsets;

public class FileUtil {
    public static String readFileFromResources(String fileName) {
        StringBuilder content = new StringBuilder();
        try {
            // 获取文件资源
            ClassPathResource resource = new ClassPathResource(fileName);
            try (BufferedReader reader = new BufferedReader(
                    new InputStreamReader(resource.getInputStream(), StandardCharsets.UTF_8))) {
                String line;
                while ((line = reader.readLine()) != null) {
                    content.append(line).append("\n");
                }
            }
        } catch (Exception e) {
            e.printStackTrace();
        }
        return content.toString();
    }
}
方法 2:使用 ClassLoader
java 复制代码
import java.io.BufferedReader;
import java.io.InputStreamReader;
import java.nio.charset.StandardCharsets;

public class FileUtil {
    public static String readFileFromResources(String fileName) {
        StringBuilder content = new StringBuilder();
        try {
            // 获取当前线程的类加载器
            ClassLoader classLoader = Thread.currentThread().getContextClassLoader();
            try (BufferedReader reader = new BufferedReader(
                    new InputStreamReader(classLoader.getResourceAsStream(fileName), StandardCharsets.UTF_8))) {
                String line;
                while ((line = reader.readLine()) != null) {
                    content.append(line).append("\n");
                }
            }
        } catch (Exception e) {
            e.printStackTrace();
        }
        return content.toString();
    }
}

示例用法

java 复制代码
public class Main {
    public static void main(String[] args) {
        String content = FileUtil.readFileFromResources("mock_data.txt");
        System.out.println(content);
    }
}

注意事项

  1. 文件路径
    • 如果文件位于 resources 的子目录下,例如 data/mock_data.txt,那么 fileName 应设置为 "data/mock_data.txt"
  2. 文件存在性
    • 确保 mock_data.txt 已经正确放置在 src/main/resources 或其子目录下。
    • 如果文件不存在或路径错误,会抛出 FileNotFoundException
  3. 编码问题
    • 读取时应指定文件的字符集(如 UTF-8),以避免乱码问题。

通过这些方法,你可以轻松读取并引用 Spring Boot 项目中 resources 目录下的文件内容。

相关推荐
Piper蛋窝几秒前
理解 Golang 中的最大/最小堆、`heap` 与优先队列
后端
不知几秋9 分钟前
Spring Boot
java·前端·spring boot
Livingbody1 小时前
Fast Whisper 语音转文本
后端
程序员岳焱1 小时前
深度剖析:Spring AI 与 LangChain4j,谁才是 Java 程序员的 AI 开发利器?
java·人工智能·后端
G探险者1 小时前
《深入理解 Nacos 集群与 Raft 协议》系列五:为什么集群未过半,系统就不可用?从 Raft 的投票机制说起
分布式·后端
G探险者1 小时前
《深入理解 Nacos 集群与 Raft 协议》系列一:为什么 Nacos 集群必须过半节点存活?从 Raft 协议说起
分布式·后端
howard20051 小时前
5.4.2 Spring Boot整合Redis
spring boot·整合redis
G探险者1 小时前
《深入理解 Nacos 集群与 Raft 协议》系列四:日志复制机制:Raft 如何确保提交可靠且幂等
分布式·后端
G探险者1 小时前
《深入理解 Nacos 集群与 Raft 协议》系列三:日志对比机制:Raft 如何防止数据丢失与错误选主
分布式·后端
G探险者1 小时前
《深入理解 Nacos 集群与 Raft 协议》系列二:Raft 为什么要“选主”?选主的触发条件与机制详解
分布式·后端