前端react后端java实现提交antd form表单成功即导出压缩包

前端(React + Ant Design)

  1. 创建表单:使用<Form>组件来创建你的表单。

  2. 处理表单提交:在onFinish回调中发起请求到后端API,并处理响应。

javascript 复制代码
import React from 'react';
import { Form, Input, Button } from 'antd';

const MyForm = () => {
  const [form] = Form.useForm();

  const onFinish = async (values) => {
    try {
      // 提交表单数据给后端API,并等待响应
      const response = await fetch('/api/submit-form', {
        method: 'POST',
        headers: {
          'Content-Type': 'application/json'
        },
        body: JSON.stringify(values)
      });

      if (!response.ok) throw new Error('Network response was not ok');

      // 处理返回的文件流
      const blob = await response.blob();
      const url = window.URL.createObjectURL(blob);
      const a = document.createElement('a');
      a.style.display = 'none';
      a.href = url;
      a.download = 'exported.zip'; // 设置下载的文件名
      document.body.appendChild(a);
      a.click();
      window.URL.revokeObjectURL(url);
      document.body.removeChild(a);

    } catch (error) {
      console.error('There was a problem with the form submission:', error);
    }
  };

  return (
    <Form form={form} name="my_form" onFinish={onFinish}>
      {/* 表单项 */}
      <Form.Item name="username" rules={[{ required: true, message: 'Please input your username!' }]}>
        <Input />
      </Form.Item>
      {/* 更多表单项... */}
      <Form.Item>
        <Button type="primary" htmlType="submit">
          Submit
        </Button>
      </Form.Item>
    </Form>
  );
};

export default MyForm;

后端(Java + Spring Boot)

假设使用的是Spring Boot作为Java后端框架,以下是如何处理前端请求并生成压缩包的示例代码:

  1. 接收表单数据:创建一个REST控制器来接收前端发送的表单数据。

  2. 生成压缩包:根据接收到的数据生成压缩包。

  3. 发送压缩包:将压缩包作为HTTP响应的一部分发送回前端。

首先,需要添加必要的依赖项到pom.xml中,例如commons-compress用于创建ZIP文件。

XML 复制代码
<dependency>
    <groupId>org.apache.commons</groupId>
    <artifactId>commons-compress</artifactId>
    <version>1.21</version>
</dependency>

然后,在控制器中处理请求:

java 复制代码
import org.springframework.web.bind.annotation.*;
import java.io.*;
import java.util.zip.ZipEntry;
import java.util.zip.ZipOutputStream;

@RestController
@RequestMapping("/api")
public class FormController {

    @PostMapping("/submit-form")
    public void handleFormSubmit(@RequestBody Map<String, Object> formData, HttpServletResponse response) throws IOException {
        // 根据formData准备要压缩的文件或文件路径列表...

        // 设置响应头以指示这是一个文件下载
        response.setContentType("application/zip");
        response.setHeader("Content-Disposition", "attachment; filename=exported.zip");

        // 创建ZIP输出流
        try (ZipOutputStream zipOut = new ZipOutputStream(response.getOutputStream())) {
            // 添加文件到ZIP存档...
            // 这里只是一个示例,你需要根据实际情况调整逻辑
            File fileToZip = new File("path/to/file.txt");
            FileInputStream fis = new FileInputStream(fileToZip);
            ZipEntry zipEntry = new ZipEntry(fileToZip.getName());
            zipOut.putNextEntry(zipEntry);

            byte[] bytes = new byte[1024];
            int length;
            while ((length = fis.read(bytes)) >= 0) {
                zipOut.write(bytes, 0, length);
            }

            zipOut.closeEntry();
            fis.close();
        }
    }
}

请注意,上述代码片段是简化版的示例,实际应用中可能需要更复杂的逻辑来处理错误、验证以及确保安全性。此外,后端部分还需要根据实际需求调整文件的压缩逻辑。如果需要压缩多个文件或目录,或者有更复杂的需求,则可能需要引入其他库或工具来辅助完成任务。

相关推荐
布兰妮甜1 分钟前
Vue 视图不更新?常见赋值踩坑点汇总
前端·javascript·vue.js·vue踩坑·vue视图不更新
东方巴黎~Sunsiny3 分钟前
后端已经开始使用AI代替前端开发了
java·人工智能·状态模式
Sam_Deep_Thinking10 分钟前
结算分摊的策略模式:不同营销活动的扣点计算方案
java·设计模式·架构·系统架构
前端 贾公子17 分钟前
uni-app工程化实战:基于vue-i18n和i18n-ally的国际化方案 (下)
前端
@zulnger25 分钟前
selenium 操作浏览器
前端·javascript·selenium
兰令水31 分钟前
leecodecode【回溯组合】【2026.6.5打卡-java版本】
java·开发语言
8Qi831 分钟前
LeetCode 518:零钱兑换 II(Coin Change II)—— 题解 ✅
java·算法·leetcode·动态规划·完全背包
cfm_291432 分钟前
SpringBoot整合RocketMQ极速实战
java·spring boot·后端
为爱停留33 分钟前
让智能体「记住」对话:Checkpoint 功能、持久化数据接口与 thread_id 详解
java·数据库·elasticsearch
xiaofeichaichai36 分钟前
Symbol 与 Iterator / Generator
前端·javascript