Node.js和express怎么实现上传大文件
导读:本文共1725字符,通常情况下阅读需要6分钟。同时您也可以点击右侧朗读,来听本文内容。按键盘←(左) →(右) 方向键可以翻页。
摘要:这篇“Node.js和express怎么实现上传大文件”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Node.js和express怎么实现上传大文件”文章吧。对于大文件的上传我们首先要引入一个叫做 multer 的库:npminstall--savemulter我们先将库引入我们的项... ...
目录
(为您整理了一些要点),点击可以直达。这篇“Node.js和express怎么实现上传大文件”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Node.js和express怎么实现上传大文件”文章吧。
对于大文件的上传我们首先要引入一个叫做 multer 的库:
npminstall--savemulter
我们先将库引入我们的项目中:
varmulter=require('multer')varupload=multer({dest:'uploads/'})//文件会上传到这个目录
具体的 get 方法:
app.post('/upload',upload.single('logo'),function(req,res){//发送json数据到这个路由console.dir(req.file);res.send(req.p);})
由于上传文件要用到表当,所以我们这里先建立一个名为 form 表单:
<!DOCTYPEhtml><htmllang="en"><head><metacharset="UTF-8"><metaname="viewport"content="width=device-width,initial-scale=1.0"><metahttp-equiv="X-UA-Compatible"content="ie=edge"><title>Document</title></head><formaction="/upload"method="post"enctype="multipart/form-data"><h3>单图上传</h3><inputtype="file"name="logo"><inputtype="submit"value="提交"></form><body></body></html>
然后我们在 server 中引入该表单:
varfs=require('fs')///from的html界面,用于演示上传文件app.get('/form',function(req,res){varform=fs.readFileSync('./form.html',{encoding:"utf8"});res.send(form);})
由 localhost:3000/form 运行后上传文件,就能在你项目的upload目录下可看到:
虽然上传成功,但w我n看到文件名是混乱的,而且路径也是固定:
修改路径和文件名:
//更改大文件的存储路径varcreateFolder=function(folder){try{fs.accessSync(folder);}catch(e){fs.mkdirSync(folder);}};varuploadFolder='./upload/';//设定存储文件夹为当前目录下的/upload文件夹createFolder(uploadFolder);//磁盘存贮varstorage=multer.diskStorage({destination:function(req,file,cb){cb(null,uploadFolder);//他会放在当前目录下的/upload文件夹下(没有该文件夹,就新建一个)},filename:function(req,file,cb){//在这里设定文件名cb(null,file.originalname);}})varupload=multer({storage:storage})
效果:
以上就是关于“Node.js和express怎么实现上传大文件”这篇文章的内容,相信大家都有了一定的了解,希望小编分享的内容对大家有帮助,若想了解更多相关的知识内容,请关注亿速云行业资讯频道。
Node.js和express怎么实现上传大文件的详细内容,希望对您有所帮助,信息来源于网络。