Busboy 上传文件到指定目录,并重命名,node.js

2024-09-04 19:38

本文主要是介绍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的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1136840

相关文章

SpringBoot内嵌Tomcat临时目录问题及解决

《SpringBoot内嵌Tomcat临时目录问题及解决》:本文主要介绍SpringBoot内嵌Tomcat临时目录问题及解决,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,... 目录SprinjavascriptgBoot内嵌Tomcat临时目录问题1.背景2.方案3.代码中配置t

springboot上传zip包并解压至服务器nginx目录方式

《springboot上传zip包并解压至服务器nginx目录方式》:本文主要介绍springboot上传zip包并解压至服务器nginx目录方式,具有很好的参考价值,希望对大家有所帮助,如有错误... 目录springboot上传zip包并解压至服务器nginx目录1.首先需要引入zip相关jar包2.然

JS+HTML实现在线图片水印添加工具

《JS+HTML实现在线图片水印添加工具》在社交媒体和内容创作日益频繁的今天,如何保护原创内容、展示品牌身份成了一个不得不面对的问题,本文将实现一个完全基于HTML+CSS构建的现代化图片水印在线工具... 目录概述功能亮点使用方法技术解析延伸思考运行效果项目源码下载总结概述在社交媒体和内容创作日益频繁的

Node.js 数据库 CRUD 项目示例详解(完美解决方案)

《Node.js数据库CRUD项目示例详解(完美解决方案)》:本文主要介绍Node.js数据库CRUD项目示例详解(完美解决方案),本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考... 目录项目结构1. 初始化项目2. 配置数据库连接 (config/db.js)3. 创建模型 (models/

使用Node.js制作图片上传服务的详细教程

《使用Node.js制作图片上传服务的详细教程》在现代Web应用开发中,图片上传是一项常见且重要的功能,借助Node.js强大的生态系统,我们可以轻松搭建高效的图片上传服务,本文将深入探讨如何使用No... 目录准备工作搭建 Express 服务器配置 multer 进行图片上传处理图片上传请求完整代码示例

Spring LDAP目录服务的使用示例

《SpringLDAP目录服务的使用示例》本文主要介绍了SpringLDAP目录服务的使用示例... 目录引言一、Spring LDAP基础二、LdapTemplate详解三、LDAP对象映射四、基本LDAP操作4.1 查询操作4.2 添加操作4.3 修改操作4.4 删除操作五、认证与授权六、高级特性与最佳

用js控制视频播放进度基本示例代码

《用js控制视频播放进度基本示例代码》写前端的时候,很多的时候是需要支持要网页视频播放的功能,下面这篇文章主要给大家介绍了关于用js控制视频播放进度的相关资料,文中通过代码介绍的非常详细,需要的朋友可... 目录前言html部分:JavaScript部分:注意:总结前言在javascript中控制视频播放

使用Python实现获取网页指定内容

《使用Python实现获取网页指定内容》在当今互联网时代,网页数据抓取是一项非常重要的技能,本文将带你从零开始学习如何使用Python获取网页中的指定内容,希望对大家有所帮助... 目录引言1. 网页抓取的基本概念2. python中的网页抓取库3. 安装必要的库4. 发送HTTP请求并获取网页内容5. 解

Linux修改pip临时目录方法的详解

《Linux修改pip临时目录方法的详解》在Linux系统中,pip在安装Python包时会使用临时目录(TMPDIR),但默认的临时目录可能会受到存储空间不足或权限问题的影响,所以本文将详细介绍如何... 目录引言一、为什么要修改 pip 的临时目录?1. 解决存储空间不足的问题2. 解决权限问题3. 提

nvm如何切换与管理node版本

《nvm如何切换与管理node版本》:本文主要介绍nvm如何切换与管理node版本问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录nvm切换与管理node版本nvm安装nvm常用命令总结nvm切换与管理node版本nvm适用于多项目同时开发,然后项目适配no