ToB企服应用市场:ToB评测及商务社交产业平台

标题: Axios 怎么通过 FormData 对象上传文件 [打印本页]

作者: 络腮胡菲菲    时间: 2024-8-13 02:04
标题: Axios 怎么通过 FormData 对象上传文件
FormData 对象介绍

FormData 是一个用于在客户端创建表单数据的接口。它可以通过 JavaScript 中的 new FormData() 构造函数创建。FormData 可以将表单字段的键值对以键值对的方式添加,同时也支持添加文件。

在文件上传的场景中,我们可以使用 FormData 对象来收集表单数据,包罗文件和其他文本字段,然后将其发送到后端服务器。

FormData 对象用于将数据编译成键值对,以便将其提交到服务器,它主要用于通过 XHR 传输文件。
使用 FormData 的主要长处:

Axios 通过 FormData 上传文件

Axios 可以通过 FormData 对象上传文件,主要有两种方法:
1. 直接在 FormData 中追加文件

直接将文件对象作为 value,追加到 FormData 中,axios 会主动对文件进行编码。
  1. const formData = new FormData();
  2. formData.append('file', fileInput.files[0]); // fileInput 为 <input type="file" />
  3. axios.post('/upload', formData)
复制代码
2. 设置 request header 的 Content-Typ

Axios 默认发送 JSON 数据,设置 headers 将 Content-Type 设置为 multipart/form-data 后,就会处理为 FormData 对象提交。
  1. const formData = new FormData();
  2. formData.append('file', fileInput.files[0]);
  3. axios.post('/upload', formData, {
  4.   headers: {
  5.     'Content-Type': 'multipart/form-data'
  6.   }
  7. })
复制代码
实践案例

为演示文件上传过程,本文将使用 Node.js 构建后端服务器。后端会提供 /upload 接口来处理文件上传请求。

1.首先,创建前端 HTML 页面,本文以 index.html 为例:
  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4.   <title>文件上传示例</title>
  5. </head>
  6. <body>
  7.   <input type="file" id="fileInput">
  8.   <button onclick="uploadFile()">上传文件</button>
  9.   <script src="axios.min.js"></script>
  10.   <script src="main.js"></script>
  11. </body>
  12. </html>
复制代码
2.然后,创建前端 JavaScript 文件 main.js,用于实现文件上传的交互逻辑:
  1. function uploadFile() {
  2.   const fileInput = document.querySelector('#fileInput');
  3.   const file = fileInput.files[0];
  4.   // 使用FormData对象上传文件
  5.   const formData = new FormData();
  6.   formData.append('file', file);
  7.   axios.post('http://localhost:5500/upload', formData, {
  8.     headers: {
  9.       'Content-Type': 'multipart/form-data'
  10.     }
  11.   }).then(response => {
  12.     console.log('上传成功', response.data);
  13.   }).catch(error => {
  14.     console.error('上传失败', error);
  15.   });
  16. }
复制代码
3.末了,创建 Node.js 后端服务器脚本(可定名为 server.js,用于接收并处理文件上传请求:
  1. const express = require("express");
  2. const multer = require("multer");
  3. const cors = require("cors"); // 引入cors中间件
  4. const app = express();
  5. const upload = multer({ dest: "uploads/" });
  6. // 使用cors中间件来设置CORS
  7. app.use(cors());
  8. app.post("/upload", upload.single("file"), (req, res) => {
  9.   const file = req.file;
  10.   console.log("已接收到文件", file);
  11.   // 在此处进行文件保存或其他处理
  12.   res.send({
  13.     code: 200,
  14.     data: "文件上传成功",
  15.   });
  16. });
  17. app.listen(5500, () => {
  18.   console.log("服务器已启动,监听端口 5500");
  19. });
复制代码
固然,为使后端服务器正常运行,还必要安装以下 Node.js 扩展模块:


免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。




欢迎光临 ToB企服应用市场:ToB评测及商务社交产业平台 (https://dis.qidao123.com/) Powered by Discuz! X3.4