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

相关文章

JS常用组件收集

收集了一些平时遇到的前端比较优秀的组件,方便以后开发的时候查找!!! 函数工具: Lodash 页面固定: stickUp、jQuery.Pin 轮播: unslider、swiper 开关: switch 复选框: icheck 气泡: grumble 隐藏元素: Headroom

变量与命名

引言         在前两个课时中,我们已经了解了 Python 程序的基本结构,学习了如何正确地使用缩进来组织代码,并且知道了注释的重要性。现在我们将进一步深入到 Python 编程的核心——变量与命名。变量是我们存储数据的主要方式,而合理的命名则有助于提高代码的可读性和可维护性。 变量的概念与使用         在 Python 中,变量是一种用来存储数据值的标识符。创建变量很简单,

在JS中的设计模式的单例模式、策略模式、代理模式、原型模式浅讲

1. 单例模式(Singleton Pattern) 确保一个类只有一个实例,并提供一个全局访问点。 示例代码: class Singleton {constructor() {if (Singleton.instance) {return Singleton.instance;}Singleton.instance = this;this.data = [];}addData(value)

Node.js学习记录(二)

目录 一、express 1、初识express 2、安装express 3、创建并启动web服务器 4、监听 GET&POST 请求、响应内容给客户端 5、获取URL中携带的查询参数 6、获取URL中动态参数 7、静态资源托管 二、工具nodemon 三、express路由 1、express中路由 2、路由的匹配 3、路由模块化 4、路由模块添加前缀 四、中间件

EasyPlayer.js网页H5 Web js播放器能力合集

最近遇到一个需求,要求做一款播放器,发现能力上跟EasyPlayer.js基本一致,满足要求: 需求 功性能 分类 需求描述 功能 预览 分屏模式 单分屏(单屏/全屏) 多分屏(2*2) 多分屏(3*3) 多分屏(4*4) 播放控制 播放(单个或全部) 暂停(暂停时展示最后一帧画面) 停止(单个或全部) 声音控制(开关/音量调节) 主辅码流切换 辅助功能 屏

Node Linux相关安装

下载经编译好的文件cd /optwget https://nodejs.org/dist/v10.15.3/node-v10.15.3-linux-x64.tar.gztar -xvf node-v10.15.3-linux-x64.tar.gzln -s /opt/node-v10.15.3-linux-x64/bin/npm /usr/local/bin/ln -s /opt/nod

android应用中res目录说明

Android应用的res目录是一个特殊的项目,该项目里存放了Android应用所用的全部资源,包括图片、字符串、颜色、尺寸、样式等,类似于web开发中的public目录,js、css、image、style。。。。 Android按照约定,将不同的资源放在不同的文件夹中,这样可以方便的让AAPT(即Android Asset Packaging Tool , 在SDK的build-tools目

Spring MVC 图片上传

引入需要的包 <dependency><groupId>commons-logging</groupId><artifactId>commons-logging</artifactId><version>1.1</version></dependency><dependency><groupId>commons-io</groupId><artifactId>commons-

遮罩,在指定元素上进行遮罩

废话不多说,直接上代码: ps:依赖 jquer.js 1.首先,定义一个 Overlay.js  代码如下: /*遮罩 Overlay js 对象*/function Overlay(options){//{targetId:'',viewHtml:'',viewWidth:'',viewHeight:''}try{this.state=false;//遮罩状态 true 激活,f

使用JS/Jquery获得父窗口的几个方法(笔记)

<pre name="code" class="javascript">取父窗口的元素方法:$(selector, window.parent.document);那么你取父窗口的父窗口的元素就可以用:$(selector, window.parent.parent.document);如题: $(selector, window.top.document);//获得顶级窗口里面的元素 $(