Busboy 上传文件到指定目录,并重命名,node.js
1,安装busboy ,在该项目下打开命令行(按住shift+右键)
npm install busboy
2,页面:必须含有(
enctype="multipart/form-data"
)
<form class="form form-signin" action="" method="post" id ="myForm" enctype="multipart/form-data"><h1 class="form-signin-heading">上传视频</h1><label for="cName" class="sr-only"></label><input id="cName" type="text" maxlength="40" placeholder="课程名称" name="lesson[name]" required autocomplete="false" autofocus /><label for="cNo" class="sr-only"></label><input type="number" id="cNo" name="lesson[no]" placeholder="目录(第几集)" /><div class="video"><span>添加视频</span><input type="file" name="videoUpload" id="cVideo" accept="video/*" /><p class="vBackg"></p></div><input type="submit" value="上传课程视频" class="btn btn-primary btn-block submit" id="sub"/>
</form>
传参:
var lName = $('#cName').val(),lNo = $('#cNo').val();$('#myForm').attr('action', "/videoUpload?lName="+lName+"&lNo="+lNo) ;
3,后台处理:
3.1,获取前台post过来的参数:
req.query.XXX
其中XXX 就是传过来的参数名,比如localhost:3000?lName=joh,就是lName,获得的就是joh
3.2 处理
router.post('/videoUpload',function(req, res) {//在这里做一个头部数据检查if(!/multipart\/form-data/i.test(req.headers['content-type'])){return res.end('wrong');}var lName,lNo;/*db = mongoose.connect(db_url),*/var filePath = path.join(path.normalize(__dirname + '/..'), 'public', 'upload');var busboy = new Busboy({ headers: req.headers });
/* db.connection.on('open', function() {console.log('lesson db connected');});*/busboy.on('file', function (fieldname, file, filename, encoding, mimetype) {console.log('File [' + fieldname + ']: aaa filename: ' + filename);console.log('lName: ' + req.query.lName + "lNo: " + req.query.lNo);lName = req.query.lName;lNo = req.query.lNo;createFlo(lName, filePath);var type = mimetype.toString();var savePath = filePath + '\\' + lName + '\\' + lNo + '.' + type.substr(type.indexOf('/') + 1, type.length);showErr(savePath);file.pipe(fs.createWriteStream(savePath));Lesson.save({lessonName: lName, lNo: lNo, creTime: Date.now()}, function (err) {showErr(err);});console.log('插入数据库成功');file.on('data', function (data) {console.log('File [' + fieldname + '] got ' + data.length + ' bytes');});file.on('end', function () {console.log('File [' + fieldname + '] Finished');});});busboy.on('field', function(fieldname, val, fieldnameTruncated, valTruncated) {console.log('Field [' + fieldname + ']: value: ' + inspect(val));});busboy.on('finish', function() {console.log('Done parsing form!');res.writeHead(200, { 'Connection': 'close' });res.end("That's all folks!");});return req.pipe(busboy);});
function createFlo(lName,filePath){var dirpath =filePath+'\\'+lName;console.log("dirpath "+dirpath);//不存在文件夹,创建if (!fs.existsSync(dirpath)) {fs.mkdirSync(dirpath, 0755);console.log( '文件夹创建成功~');}
}
function showErr(err) {console.log("info / err: "+ err);
}
还包括上传数据库的代码,大家也可以参考
Busboy 上传文件到指定目录,并重命名,node.js相关推荐
- linux上传文件至指定目录下,node上传文件到linux服务器指定路径
'use strict' const Client = require('ssh2-sftp-client') const config = { path: { // 远程地址 romotePath: ...
- 使用WinSCP上传文件到指定服务器
使用WinSCP上传文件到指定服务器 文章目录 使用WinSCP上传文件到指定服务器 前言 安装WinSCP 新建站点 传输文件 实现公网访问 前言 个人认为 FlashFTP是一款十分好用的文件上传 ...
- java web ftp上传_java web FTPClient实现上传文件到指定服务器
FPClient 实现上传文件到指定服务器,供大家参考,具体内容如下 调用 FileInputStream in=new FileInputStream(new File(fileUrl)); mov ...
- obs上传文件到服务器,obs上传文件到指定路径
obs上传文件到指定路径 内容精选 换一换 需提前准备好OBS桶名.vi /opt/huawei/obsutil_adapter/obsutil_adapter.cfgbackup_path和back ...
- python2.7通过scp上传文件到指定服务器
1 说明 实现功能: 扫描指定文件目录下文件,通过scp上传到指定服务器目录下 程序结构简单说明: 包含两个线程,线程一:扫描文件线程:线程二:消费文件线程: 线程一:扫描指定文件目录下文件,把符合要 ...
- nodeJs中间件Multer详解_使用express实现本地文件/图片上传到服务器指定目录
最终实现的效果,更改Input的值后,将图片显示出来.输入描述信息,提交后,图片上传到后台对应的路径下. Multer Multer 是一个node.js中间件,用于处理 multipart/form ...
- Java实现上传文件到指定服务器指定目录
前言需求 使用freemarker生成的静态文件,统一存储在某个服务器上.本来一开始打算使用ftp实现的,奈何老连接不上,改用jsch.毕竟有现成的就很舒服,在此介绍给大家. 具体实现 引入的pom ...
- php上传文件到指定文件夹
效果图如下: 首先我们需要一个index.html页面上传文件: <!DOCTYPE html> <html> <head><meta charset=&qu ...
- egg.js ajax上传文件,egg.js 通过 form 和 ajax 两种方式上传文件并自定义目录和文件名...
一.需求 egg.js 的文件上传个人觉得很一般,内置的 multipart 插件并不怎么好用. egg-multipart 也是基于 co-busboy 实现的. egg 官方给的文件上传的示例地址 ...
- javascript构造可以上传文件的form表单(通过js修改enctype)
在上传文件时,我们都知道需要在form表单中加上enctype="multipart/form-data".而在开发过程中,也有可能遇到需要用javascripts构造form表单 ...
最新文章
- R语言进行dataframe数据左连接(Left join):使用R原生方法、data.table、dplyr等方案
- 用haproxy结合keepalived实现基于LNMP的负载均衡和高可用
- opencv undefined reference to symbol '_ZN2c...异常
- Linux下gcc中各种文件后缀说明
- Android 计算Bitmap大小
- 获取指定长度的随机字符串
- BSP技术详解3---有图有真相
- Jquery1.6版本后attr的变化
- [转载] python学习笔记2--操作符,数据类型和内置功能
- #include,#import ,@class 有什么区别?
- 震惊,CSDN居然可以打出爱心?
- pfa100_什么是PFA?
- int java 时间,java 时间处理类
- WLAN中直接转发和隧道转发流程与封装
- vmware workstation 12 打开vm14 不兼容问题解决
- 1编写偏移量为3的凯撒密码大小写混合加密程序(50分)
- 怎么看计算机配件型号,操作方法:如何查看CPU型号,教您如何通过CPU型号[图形]识别计算机的性能...
- Java实现腾讯企业邮箱收发邮件
- 轻量级kali虚拟机
- 李沐动手学深度学习V2-BERT微调和代码实现