首页
学习
活动
专区
圈层
工具
发布
社区首页 >专栏 >Node.js + express来上传大文件(图片、文本文件)附视频教程

Node.js + express来上传大文件(图片、文本文件)附视频教程

作者头像
圆号本昊
发布2021-09-24 12:00:30
发布2021-09-24 12:00:30
2.2K0
举报
文章被收录于专栏:github@hornhuanggithub@hornhuang

视频链接与文末给出,本文代码均在VS Code 中运行。

对于大文件的上传我们首先要引入一个叫做 multer 的库:

代码语言:javascript
复制
npm install --save multer

关于这个库,大家可以查阅官方文档:

点击跳转 https://www.npmjs.com/package/multer

我们先将库引入我们的项目中:

代码语言:javascript
复制
var multer  = require('multer')
var upload = multer({ dest: 'uploads/' })// 文件会上传到这个目录

具体的 get 方法:

代码语言:javascript
复制
app.post('/upload', upload.single('logo'), function(req, res){//发送 json 数据到这个路由
    console.dir(req.file);
    res.send(req.p);
})

由于上传文件要用到表当,所以我们这里先建立一个名为 form 表单:

代码语言:javascript
复制
    Document

    
        单图上传

然后我们在 server 中引入该表单:

代码语言:javascript
复制
var fs = require('fs')

// /from 的 html 界面,用于演示上传文件
app.get('/form',function(req, res){
    var form = fs.readFileSync('./form.html',{ encoding : "utf8"});
    res.send(form);
})

由 localhost:3000/form 运行后上传文件,就能在你项目的upload目录下可看到:

虽然上传成功,但w我n看到文件名是混乱的,而且路径也是固定:

修改路径和文件名:

代码语言:javascript
复制
// 更改大文件的存储路径
var createFolder = function(folder){
    try{
        fs.accessSync(folder);
    }catch( e ){
        fs.mkdirSync(folder);
    }
};

var uploadFolder = './upload/';// 设定存储文件夹为当前目录下的 /upload 文件夹

createFolder(uploadFolder);

// 磁盘存贮
var storage = multer.diskStorage({
    destination: function (req, file, cb) {
        cb(null, uploadFolder );// 他会放在当前目录下的 /upload 文件夹下(没有该文件夹,就新建一个)
    },
    filename: function (req, file, cb) {// 在这里设定文件名
        cb(null, file.originalname );
    }
})
   
var upload = multer({ storage: storage })

效果:

最后,这里是视屏连接方便大家学习:

点击跳转 https://www.bilibili.com/video/av24385038/?p=6

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2019/02/26 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 虽然上传成功,但w我n看到文件名是混乱的,而且路径也是固定:
    • 最后,这里是视屏连接方便大家学习:
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档