欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

文件小能手---multer

程序员文章站 2024-03-16 10:10:10
...

目标

掌握multer 模块的用法

multer

一个非常好用的文件上传模块,官方地址:https://www.npmjs.com/package/multer
同时 formidable 模块也比较好用,推荐阅读:formidable 使用

1. 用法

此处对项目中比较常用的用法做下总结:

  1. 首先安装 multer 模块
npm install --save multer
  1. 导入此模块并进行基础配置
const multer = require('multer');
const upload = multer({ dest: './public/uploads' }).single('file'); //上传单个文件

app.post('/multertest', upload, (req, res) => {
    res.send(req.file)
})

注意:此处的 uploads 路径是相对于服务器的

  1. 测试接口(图片为例)

①:用 Postman 进行测试

文件小能手---multer

②:用真实表单模拟提交

表单代码:

注意此处一定要写上:enctype="multipart/form-data"

 <form action="/multertest" method="POST" enctype="multipart/form-data">
        <input type="file" name="file">
        <input type="submit" value="提交">
    </form>

提交结果:
文件小能手---multer

  1. 服务器uploads 文件夹

文件小能手---multer

总结:可以看到 uploads 文件夹下的图片无后缀,若存入数据库,可控性较低,所以我们需对 file上传的文件 进行处理

2. 信息处理

在实际项目中,我们往往会希望拿到图片上传到服务器的路径,然后把路径存入数据库,待到使用时,请求图片路径,写入src 属性。

①:node示例:

const multer = require('multer');
const fs = require('fs');
const upload = multer({ dest: './public/uploads' }).single('file');

app.post('/multertest', upload, (req, res) => {
    let file = req.file;
    // fs.renameSync(oldname,newname);此方法用于改变文件名(文件的oldname与newname均在file对象中)
    fs.renameSync('./public/uploads/' + file.filename, './public/uploads/' + file.originalname);
    let imgurl = 'http://localhost:3000/uploads/' + file.originalname;
    res.send(imgurl)
})

②:Postman 测试

文件小能手---multer

③:服务器uploads 文件夹

文件小能手---multer

此时不管是存入数据库,还是直接访问,都变得简单直接。

3. 多文件上传

多文件上传和单文件相似,只是在创建路径参数时,对其进行限制,演示略,直接上示例

示例:

const multer = require('multer');
const fs = require('fs');
let uploadMore = multer({ dest: './public/uploads' }).array('file', 5);// 此处以5为例(上传数<= 5)

app.post('/multertest', uploadMore , (req, res) => {
  let files = req.files;
  for (var k in files) {
            let file = files[k];
            fs.renameSync('./public/uploads/' + file.filename, './public/uploads/' + file.originalname);
            let url = 'http:localhost:3000/uploads' + file.originalname;
            }
})

over

相关标签: Node

上一篇: 【Python】类与对象(下)

下一篇: