当前位置:首页 > 文章列表 > 文章 > java教程 > Java生成CSV并上传FTP教程

Java生成CSV并上传FTP教程

2025-08-08 23:18:36 0浏览 收藏

学习知识要善于思考,思考,再思考!今天golang学习网小编就给大家带来《Java动态生成CSV并上传FTP教程》,以下内容主要包含等知识点,如果你正在学习或准备学习文章,就都不要错过本文啦~让我们一起来看看吧,能帮助到你就更好了!

Java Structs 中动态创建 CSV 文件并上传到 FTP 服务器的教程

本文将介绍如何在 Java Structs 框架中,基于 ArrayList 的数据动态生成 CSV 文件,并将其上传到 FTP 服务器。我们将避免在磁盘上创建实际文件,而是利用 ByteArrayOutputStream 和 ByteArrayInputStream 在内存中处理文件数据,从而提高效率。最后,我们会提供一个完整的代码示例,并讨论相关的注意事项。

动态生成 CSV 文件

在传统的 Java 文件操作中,我们通常需要先创建一个 File 对象,然后通过 FileWriter 将数据写入到文件中。但是,在某些场景下,我们并不需要将文件持久化到磁盘上,而是直接将其上传到 FTP 服务器。这时,我们可以使用 ByteArrayOutputStream 和 ByteArrayInputStream 来在内存中生成 CSV 文件。

ByteArrayOutputStream 允许我们将数据写入到内存中的字节数组中,而 ByteArrayInputStream 则允许我们从内存中的字节数组中读取数据,从而实现文件数据的动态生成和读取。

以下是使用 ByteArrayOutputStream 和 ByteArrayInputStream 生成 CSV 文件的示例代码:

import java.io.*;

public class CSVGenerator {

    public static InputStream generateCSV(String[] business, String[] position) throws IOException {
        ByteArrayOutputStream bos = new ByteArrayOutputStream();
        try (Writer writer = new OutputStreamWriter(bos)) {
            // 写入 CSV 文件的头部(如果需要)
            writer.write("Business,Position\n");

            // 写入 business 数据
            for (String b : business) {
                writer.write(b + ",");
            }

            // 写入 position 数据
            for (String p : position) {
                writer.write(p + ",");
            }

            writer.write("\n"); //换行符

        }
        return new ByteArrayInputStream(bos.toByteArray());
    }
}

代码解释:

  1. ByteArrayOutputStream bos = new ByteArrayOutputStream();:创建一个 ByteArrayOutputStream 对象,用于存储 CSV 文件的数据。
  2. try (Writer writer = new OutputStreamWriter(bos)) { ... }:使用 try-with-resources 语句创建 OutputStreamWriter 对象,确保资源在使用完毕后被正确关闭。
  3. writer.write("Business,Position\n");:写入 CSV 文件的头部,包括列名。根据实际需求修改。
  4. for (String b : business) { writer.write(b + ","); }:遍历 business 数组,将每个元素写入 CSV 文件,并以逗号分隔。
  5. for (String p : position) { writer.write(p + ","); }:遍历 position 数组,将每个元素写入 CSV 文件,并以逗号分隔。
  6. return new ByteArrayInputStream(bos.toByteArray());:将 ByteArrayOutputStream 中的数据转换为字节数组,并创建 ByteArrayInputStream 对象,返回该对象。

上传 CSV 文件到 FTP 服务器

有了 CSV 文件的 InputStream,我们就可以将其上传到 FTP 服务器了。以下是上传 CSV 文件到 FTP 服务器的示例代码(假设你已经有一个 SISSFTPManager 类来处理 FTP 上传):

import java.io.InputStream;
import java.io.IOException;

public class FTPUploader {

    public boolean uploadFile(InputStream isUploadFile, String dirName, String loggedInUser, String fileName) {
        boolean storeRetVal = false;
        String fileType = fileName.substring(fileName.lastIndexOf(".") + 1, fileName.length());
        storeRetVal = SISSFTPManager.getInstance().put(isUploadFile, dirName, fileName);
        if (storeRetVal) {
            try {
                if (fileType.trim().equalsIgnoreCase("csv")) {
                    ICSAPI.getInstance().getSIMSOrderManager().createFileAudit(loggedInUser, fileName);
                } else {
                    // Handle other file types if needed
                }
            } catch (Exception e) {
                // TODO: Handle exceptions appropriately (logging, etc.)
                e.printStackTrace();
            }
            System.out.println("BulkUploadAction:fileUpload SFTP Transfer file successfully!");
        } else {
            System.err.println("BulkUploadAction:fileUpload SFTP Transfer file FAILED!");
        }

        return storeRetVal;
    }
}

代码解释:

  1. SISSFTPManager.getInstance().put(isUploadFile, dirName, fileName);:调用 SISSFTPManager 类的 put 方法,将 InputStream 中的数据上传到 FTP 服务器。 dirName 指定上传的目录, fileName 指定上传的文件名。
  2. if (fileType.trim().equalsIgnoreCase("csv")) { ... }:判断文件类型是否为 CSV,如果是,则执行相应的操作(例如,创建文件审计记录)。
  3. 异常处理:添加适当的异常处理,例如日志记录,以确保应用程序的稳定性和可靠性。

在 Java Structs Action 中使用

现在,我们将上述代码集成到 Java Structs Action 中。以下是修改后的 generatePayroll 方法:

import org.apache.struts.action.Action;
import org.apache.struts.action.ActionForm;
import org.apache.struts.action.ActionForward;
import org.apache.struts.action.ActionMapping;

import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.InputStream;
import java.io.IOException;

public class PayrollAction extends Action {

    @Override
    public ActionForward generatePayroll(ActionMapping mapping, ActionForm form,
                                          HttpServletRequest request, HttpServletResponse response) {
        SessionInfoForm _form = (SessionInfoForm) form;
        SisTransactionsSession _config = _form.getSisTransactionsSession();
        String loggedInUser = _form.getLoggedinEmployeeDVO().getLoginId().toUpperCase();
        String[] business = request.getParameterValues("selectedBusinessValues");
        String[] position = request.getParameterValues("selectedPositionValues");

        try {
            // 1. Generate CSV InputStream
            InputStream isFixedValue = CSVGenerator.generateCSV(business, position);

            // 2. Upload to FTP
            FTPUploader ftpUploader = new FTPUploader();
            String fileName = "PAYROLL_PRM.csv"; // Define your filename
            String dirName = "/payroll"; // Define your directory on the FTP server

            boolean uploadSuccess = ftpUploader.uploadFile(isFixedValue, dirName, loggedInUser, fileName);

            if (uploadSuccess) {
                System.out.println("Payroll file uploaded successfully!");
            } else {
                System.err.println("Payroll file upload failed!");
            }

        } catch (IOException e) {
            // TODO: Handle exceptions appropriately (logging, error page, etc.)
            e.printStackTrace();
        }

        return mapping.findForward("success");
    }
}

代码解释:

  1. 获取请求参数 business 和 position,这些参数将用于生成 CSV 文件。
  2. 调用 CSVGenerator.generateCSV(business, position) 方法,生成 CSV 文件的 InputStream。
  3. 创建 FTPUploader 对象,并调用其 uploadFile 方法,将 CSV 文件上传到 FTP 服务器。
  4. 根据上传结果,打印相应的日志信息。
  5. 异常处理:添加适当的异常处理,例如日志记录,错误页面跳转等,以确保应用程序的稳定性和可靠性。

注意事项

  • 异常处理: 在实际开发中,需要对可能出现的异常进行处理,例如 IOException,FtpException 等。
  • FTP 连接: 确保 FTP 服务器的连接配置正确,包括主机名、端口号、用户名和密码。
  • 字符编码: 确保 CSV 文件的字符编码与 FTP 服务器的字符编码一致,避免出现乱码问题。
  • 安全性: 在生产环境中,需要对 FTP 连接进行加密,例如使用 SFTP 或 FTPS。
  • 资源释放: 确保在使用完毕后,正确关闭 InputStream 和 OutputStream 等资源。

总结

本文介绍了如何在 Java Structs 框架中,基于 ArrayList 的数据动态生成 CSV 文件,并将其上传到 FTP 服务器。通过使用 ByteArrayOutputStream 和 ByteArrayInputStream,我们可以避免在磁盘上创建实际文件,从而提高效率。同时,我们也提供了一个完整的代码示例,并讨论了相关的注意事项。希望本文能够帮助你更好地理解和应用 Java 文件操作和 FTP 上传技术。

以上就是本文的全部内容了,是否有顺利帮助你解决问题?若是能给你带来学习上的帮助,请大家多多支持golang学习网!更多关于文章的相关知识,也可关注golang学习网公众号。

Go数组传入JS函数教程Go数组传入JS函数教程
上一篇
Go数组传入JS函数教程
Python内存回收机制全解析
下一篇
Python内存回收机制全解析
查看更多
最新文章
查看更多
课程推荐
  • 前端进阶之JavaScript设计模式
    前端进阶之JavaScript设计模式
    设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
    543次学习
  • GO语言核心编程课程
    GO语言核心编程课程
    本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
    516次学习
  • 简单聊聊mysql8与网络通信
    简单聊聊mysql8与网络通信
    如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
    499次学习
  • JavaScript正则表达式基础与实战
    JavaScript正则表达式基础与实战
    在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
    487次学习
  • 从零制作响应式网站—Grid布局
    从零制作响应式网站—Grid布局
    本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
    484次学习
查看更多
AI推荐
  • ModelGate:AI模型工程化全栈平台 | 多模型管理、智能编排与企业协作,释放AI开发生产力
    ModelGate
    ModelGate是国内首个聚焦「模型工程化」的全栈式AI开发平台。解决多模型调用复杂、开发成本高、协作效率低等痛点,提供模型资产管理、智能任务编排、企业级协作功能。已汇聚120+主流AI模型,服务15万+开发者与3000+企业客户,是AI时代的模型管理操作系统,全面提升AI开发效率与生产力。
    16次使用
  • 造点AI:阿里巴巴AI创作平台,图像与视频创作新体验
    造点AI
    探索阿里巴巴造点AI,一个集图像和视频创作于一体的AI平台,由夸克推出。体验Midjourney V7和通义万相Wan2.5模型带来的强大功能,从专业创作到趣味内容,尽享AI创作的乐趣。
    62次使用
  • PandaWiki开源知识库:AI大模型驱动,智能文档与AI创作、问答、搜索一体化平台
    PandaWiki开源知识库
    PandaWiki是一款AI大模型驱动的开源知识库搭建系统,助您快速构建产品/技术文档、FAQ、博客。提供AI创作、问答、搜索能力,支持富文本编辑、多格式导出,并可轻松集成与多来源内容导入。
    510次使用
  • SEO  AI Mermaid 流程图:自然语言生成,文本驱动可视化创作
    AI Mermaid流程图
    SEO AI Mermaid 流程图工具:基于 Mermaid 语法,AI 辅助,自然语言生成流程图,提升可视化创作效率,适用于开发者、产品经理、教育工作者。
    1287次使用
  • 搜获客笔记生成器:小红书医美爆款内容AI创作神器
    搜获客【笔记生成器】
    搜获客笔记生成器,国内首个聚焦小红书医美垂类的AI文案工具。1500万爆款文案库,行业专属算法,助您高效创作合规、引流的医美笔记,提升运营效率,引爆小红书流量!
    1321次使用
微信登录更方便
  • 密码登录
  • 注册账号
登录即同意 用户协议隐私政策
返回登录
  • 重置密码