当前位置: 首页 > article >正文

node(multer)上传文件

node(multer)上传文件

from表单上传文件

前端代码

import React from 'react';
import { Form, Button, Upload, message } from 'antd';
import { UploadOutlined } from '@ant-design/icons';
import axios from 'axios';

const FileUploadForm = () => {
  const onFinish = async (values) => {
    const formData = new FormData();
    const file = values.file[0].originFileObj;  // 获取文件

    formData.append('file', file);

    try {
      const response = await axios.post('http://localhost:5000/upload', formData, {
        headers: {
          'Content-Type': 'multipart/form-data',
        },
      });
      message.success('文件上传成功');
    } catch (error) {
      message.error('文件上传失败');
    }
  };

  return (
    <Form onFinish={onFinish}>
      <Form.Item
        name="file"
        label="上传文件"
        rules={[{ required: true, message: '请选择一个文件!' }]}
      >
        <Upload
          beforeUpload={() => false}  // 阻止自动上传,手动处理上传
          accept=".jpg,.png,.pdf,.docx,.txt"  // 设置文件类型限制
        >
          <Button icon={<UploadOutlined />}>选择文件</Button>
        </Upload>
      </Form.Item>

      <Form.Item>
        <Button type="primary" htmlType="submit">
          上传
        </Button>
      </Form.Item>
    </Form>
  );
};

export default FileUploadForm;

后端代码

const express = require('express');
const multer = require('multer');
const path = require('path');
const app = express();
const PORT = 5000;

// 配置 multer 存储选项
const storage = multer.diskStorage({
  destination: (req, file, cb) => {
    cb(null, 'uploads/'); // 文件保存的目录
  },
  filename: (req, file, cb) => {
    cb(null, Date.now() + path.extname(file.originalname)); // 保证文件名唯一
  },
});

// 创建 multer 实例
const upload = multer({ storage: storage });

// 创建上传路由
app.post('/upload', upload.single('file'), (req, res) => {
  // 检查文件是否上传
  if (!req.file) {
    return res.status(400).send('没有文件上传');
  }

  res.status(200).send({
    message: '文件上传成功',
    file: req.file,
  });
});

// 设置静态目录,使得可以通过 URL 访问上传的文件
app.use('/uploads', express.static('uploads'));

app.listen(PORT, () => {
  console.log(`Server is running on http://localhost:${PORT}`);
});


http://www.kler.cn/a/429991.html

相关文章:

  • 美国大学的计算机科学专业排名
  • 通过gradle发布aar或jar携带sources-jar到maven nexus
  • 用c实现C++类(八股)
  • kubernetes第七天
  • springboot整合拦截器
  • 【面试题】技术场景 4、负责项目时遇到的棘手问题及解决方法
  • 4K高清壁纸网站推荐
  • 【TCP 网络通信(发送端 + 接收端)实例 —— Python】
  • 《操作系统》(408非PV操作大题)
  • 【生信刺客】11分的WGCNA+网络药理学+分子对接+体内外实验
  • 数据结构初阶---栈和队列
  • 如何选择安全、可验证的技术?
  • Ubuntu系统上mysql服务部署
  • C#实现一个HttpClient集成通义千问-流式输出内容提取
  • 鸿蒙特色实战2
  • 商业银行基于容器云的分布式数据库架构设计与创新实践
  • JavaScript 数组的高级用法与最佳实践
  • 如何解决 java.nio.charset.CoderMalfunctionError: 编码器故障错误问题?亲测有效的解决方法!
  • 分布式搜索引擎之elasticsearch基本使用1
  • Java快速分组技术解析
  • 1.1 Beginner Level学习之“编写简单的发布服务器和订阅服务器”(第十二节)
  • 逆波兰算法详解及应用(计算数学表达式)
  • 自动驾驶领域常用的软件与工具
  • 使用Docker安装Qdrant向量数据库
  • 013-SpringBoot 定义优雅的全局异常处理方式
  • ubuntu20.04安装anygrasp_sdk