Node.js + express实现上传大文件的方法分析【图片、文本文件】
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了Node.js + express实现上传大文件的方法分析【图片、文本文件】,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1988字,纯文字阅读大概需要3分钟。
内容图文
本文实例讲述了Node.js + express实现上传大文件的方法。分享给大家供大家参考,具体如下:
对于大文件的上传我们首先要引入一个叫做 multer 的库:
npm install --save multer
关于这个库,大家可以查阅官方文档:
点击跳转 https://www.npmjs.com/package/multer
我们先将库引入我们的项目中:
var multer = require('multer') var upload = multer({ dest: 'uploads/' })// 文件会上传到这个目录
具体的 get 方法:
app.post('/upload', upload.single('logo'), function(req, res){//发送 json 数据到这个路由 console.dir(req.file); res.send(req.p); })
由于上传文件要用到表当,所以我们这里先建立一个名为 form 表单:
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <meta http-equiv="X-UA-Compatible" content="ie=edge"> <title>Document</title> </head> <form action="/upload" method="post" enctype="multipart/form-data"> <h2>单图上传</h2> <input type="file" name="logo"> <input type="submit" value="提交"> </form> <body> </body> </html>
然后我们在 server 中引入该表单:
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看到文件名是混乱的,而且路径也是固定:
修改路径和文件名:
// 更改大文件的存储路径 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
希望本文所述对大家nodejs程序设计有所帮助。
内容总结
以上是互联网集市为您收集整理的Node.js + express实现上传大文件的方法分析【图片、文本文件】全部内容,希望文章能够帮你解决Node.js + express实现上传大文件的方法分析【图片、文本文件】所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。