
在当前目录下创建一个名为 upload-image-api
的新文件夹,并初始化一个包含默认设置的 package.json
文件。
mkdir upload-image-api && cd upload-image-api npm init -y
express
是一个流行的 Node.js Web 框架;multer
是一个用于处理文件上传的中间件。
npm install express multer
在根目录下创建一个 index.js
入口文件,并实现简单的上传图片逻辑。
const express = require("express"); const multer = require("multer"); const path = require("path"); const app = express(); // 设置存储路径和文件名称 const storage = multer.diskStorage({ destination: path.join(__dirname, "uploads"), filename: (req, file, cb) => { const uniqueSuffix = Date.now() + "-" + Math.round(Math.random() * 1e9); cb( null, file.fieldname + "-" + uniqueSuffix + path.extname(file.originalname) ); }, }); // 创建文件上传中间件 const upload = multer({ storage: storage }); /** * 处理文件上传请求 * upload.single('image') 函数中 `image` 为接收文件的参数名 */ app.post("/upload", upload.single("image"), (req, res, next) => { if (!req.file) { return res.status(400).json({ error: "No file uploaded" }); } const filePath = req.file.path; res.json({ filePath: filePath }); }); // 启动服务器 const port = 3000; app.listen(port, () => { console.log(`Server is running on port ${port}`); });
测试上传图片接口
node index.js
Postman
或其他工具来测试图片上传接口。http://localhost:3000/upload
发送 POST
请求,并以 multipart/form-data
格式附加一个名为 image
的字段来上传图片。到此这篇关于用 Node.js 实现一个上传图片接口的文章就介绍到这了,更多相关Node.js 上传图片接口内容请搜索本站以前的文章或继续浏览下面的相关文章希望大家以后多多支持本站!