Java 实现TXT文件上传并解析的Spring Boot应用

在本篇博客中,我们将探讨如何使用Spring Boot框架实现一个简单的功能:通过HTTP POST请求上传TXT文件,并对文件内容进行解析。此示例适用于处理包含特定格式数据的文本文件,如用户存款信息等。

1. 添加必要的依赖

首先,确保你的​​pom.xml​​​或​​build.gradle​​文件中包含了必要的依赖项。对于这个例子,我们需要Spring Web和Apache Commons IO库来简化文件操作:

xml 复制代码
<dependencies>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-web</artifactId>
    </dependency>
    <dependency>
        <groupId>commons-io</groupId>
        <artifactId>commons-io</artifactId>
        <version>2.8.0</version>
    </dependency>
</dependencies>

2. 创建控制器方法

接下来,我们创建一个控制器类,用于处理文件上传和解析逻辑。以下是完整的代码示例:

java 复制代码
import org.apache.commons.io.IOUtils;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.web.bind.annotation.*;
import org.springframework.web.multipart.MultipartFile;

import java.io.BufferedReader;
import java.io.InputStreamReader;
import java.util.ArrayList;
import java.util.List;

@RestController
public class FileUploadController {

    private static final Logger logger = LoggerFactory.getLogger(FileUploadController.class);

    @PostMapping("/feeDaysImport")
    public AjaxResult feeDaysImport(@RequestParam("file") MultipartFile file) throws Exception {
        List<DepositInfo> depositInfoList = new ArrayList<>();
        // 校验文件后缀名是否是 txt
        if (file.getOriginalFilename().toLowerCase().endsWith(".txt")) {
            try (BufferedReader reader = new BufferedReader(new InputStreamReader(file.getInputStream()))) {
                StringBuilder lineAllContent = new StringBuilder();
                String lineContent = "";
                String line;
                while ((line = reader.readLine()) != null) {
                    if (line.contains("USER:") || line.contains("PGM:") || line.contains("CARRIER :")) {
                        continue;
                    }
                    if ("".equals(line.trim())) {
                        if (!lineContent.trim().isEmpty()) {
                            lineAllContent.append(lineContent).append("FINISH");
                            lineContent = "";
                        }
                        continue;
                    } else {
                        lineContent += line + "\n";
                    }
                }
                if (!lineContent.trim().isEmpty()) { // 处理最后一段可能未被追加的内容
                    lineAllContent.append(lineContent).append("FINISH");
                }
                System.out.println("文本全部内容:" + lineAllContent.toString());
                //依照需求解析每行数据
                return AjaxResult.success("操作成功", depositInfoList);
            } catch (Exception e) {
                logger.error("操作失败: " + e.getMessage(), e);
                return AjaxResult.error("操作失败");
            }
        } else {
            logger.error("上传模板格式错误,请上传txt格式文件");
            return AjaxResult.error("上传模板格式错误,请上传txt格式文件");
        }
    }
}

3. 注意事项与优化建议

  • 资源管理 :在这个例子中,我们使用了try-with-resources语句来自动关闭​BufferedReader​,从而避免资源泄露。
  • 日志记录:使用SLF4J进行日志记录,可以帮助我们更好地追踪程序执行过程中的问题。
  • 异常处理:捕获所有可能的异常,并返回有意义的错误消息给客户端。
  • 扩展性:根据实际业务需求,可以进一步扩展此方法以支持更多类型的文件上传和更复杂的文件内容解析逻辑。

通过上述步骤,我们可以轻松地在Spring Boot应用程序中实现文件上传和解析的功能。这不仅提高了开发效率,也为后续维护提供了便利。

相关推荐
程序猿追1 小时前
我搭了个网页工具:输入关键词,SERP API 自动吐出比价 Excel
后端
Lee川1 小时前
RAG 实战:从一篇掘金文章出发,拆解检索增强生成的全链路
前端·人工智能·后端
Lee川1 小时前
MCP 高德地图实战:当 AI 学会使用工具,一个协议如何重塑大模型的行动边界
前端·人工智能·后端
楼田莉子2 小时前
C++17新特性:__had_include/属性/求值顺序规则
开发语言·c++·后端
程序员cxuan2 小时前
Codex 把我家烂网给优化后,我 TM 直接原地起飞了。
人工智能·后端·程序员
IT_陈寒2 小时前
Redis批量删除踩了坑,原来DEL命令不是万能的
前端·人工智能·后端
沪漂阿龙2 小时前
Hermes Agent Sessions 架构详解:AI 如何跨平台延续任务、找回历史、持续推进工作
人工智能·架构
500842 小时前
昇腾 CANN 的五层架构,到底分了哪五层
java·人工智能·分布式·架构·ocr·wpf
叫我少年3 小时前
C# 命名空间与 using 指令 — 文件范围、全局导入、别名
后端
贵慜_Derek3 小时前
《从零实现 Agent 系统》连载 07|记忆系统:短期上下文 vs 长期外部记忆
人工智能·设计模式·架构