Node.js+express如何实现上传大文件
小编给大家分享一下Node.js+express如何实现上传大文件,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!
创新互联建站于2013年创立,公司以成都网站设计、成都网站制作、系统开发、网络推广、文化传媒、企业宣传、平面广告设计等为主要业务,适用行业近百种。服务企业客户上千家,涉及国内多个省份客户。拥有多年网站建设开发经验。为企业提供专业的网站建设、创意设计、宣传推广等服务。 通过专业的设计、独特的风格,为不同客户提供各种风格的特色服务。
具体如下:
对于大文件的上传我们首先要引入一个叫做 multer 的库:
npm install --save 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 表单:
Document
然后我们在 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 })
效果:
以上是“Node.js+express如何实现上传大文件”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注创新互联行业资讯频道!
文章标题:Node.js+express如何实现上传大文件
标题链接:http://pwwzsj.com/article/ggjhdd.html