Node 文件上传,ZIP
上传文件:
很多人会使用第三包进行文件的上传,例如formidable。
我也研究过,可是与Express3.x框架一起使用时,发现上传的文件总是找不到。结果原因是下面这句导致:
app.use(express.bodyParser({'uploadDir:xxx'}));
Node端上传文件会将上传的文件临时保存到一个目录,然后再通过我们码的代码来移动文件到我们的指定目录;
因为Express3.x的默认上传临时目录和formidable的临时上传目录不一致,所以formidable一直找不到上传的文件。
另外formidable还有个BUG,可以参考https://cnodejs.org/topic/4f5c62932373009b5c0b027b。
下面介绍不通过第三方包,express原生态的上传文件方式:
1.前台写法, 很简单,form表单提交。 注意input file控件的name属性,这个和后台会有关联。
<form action="后台路由" enctype="multipart/form-data" method="post">
<input type="file" name="upload" multiple="multiple"><br>
<input type="submit" value="Upload">
</form>
2.后台写法
app.post('/upload', function (req, res, next) {
//req.files即为上传文件对象,req.files.upload这里的upload即为你前台input file控件的name属性值
//获得上传文件的类型(各上传文件的类型请参考MIME)
var file_type = req.files.upload.type;
//判断上传类型,在此只能上传图片类型
if (file_type != "image/png" && file_type != "image/jpeg" && file_type != "image/bmp" &&
file_type != "image/gif") {
return res.jsonp({ success: 0, msg: 'FileType is Error' });
}
//临时文件路径
var tempPath = req.files.upload.path;
//临时路径也有了,下来就是通过fs进行文件的移动,重命名,以及删除临时文件的操作了。再次就不多写了
})
压缩与解压缩
压缩包模块:easy-zip2 解压缩包模块:unzip
当时找这个压缩包模块费了好大的劲,例如adm-zip等等,虽然星多,可是测下来或多或少都有问题。
直接上代码:
var easyzip = require('easy-zip2');
/**
* 压缩包(只能压缩文件夹)
* @param folder 压缩文件夹路径
* @param zipname 压缩包路径(带zip后缀)
* @param callback 回调
*/
var zip = function (folder, zipname, callback) {
callback = callback ? callback : function () {
};
var zip = new easyzip.EasyZip();
//添加压缩文件夹
zip.zipFolder(folder, function (err) {
if (err) return callback("Folder is not find", null);
//压缩文件
zip.writeToFile(zipname, function (err) {
if (err) return callback(err, null);
callback(null, 'ok');
});
});
}
上面我是压缩整个文件夹,当然也能压缩文件,具体的请自己去查找学习。
var unzips = require('unzip');
/**
* 解压缩包
* @param zipPath 压缩包路径
* @param unzipPath 解压路径
* @param callback 回调
*/
function unzip(zipPath, unzipPath, callback) {
callback = callback ? callback : function () {
};
//判断是否存在压缩包
fs.exists(zipPath, function (exists) {
if (!exists) return callback('zipPath is not esists', null);
//以流的方式进行解压缩
var unzipExtractor = unzips.Extract({ path: unzipPath });
//添加错误监听事件
unzipExtractor.on('error', function (err) {
callback(err, null);
});
//添加完成监听事件
unzipExtractor.on('close', function () {
callback(null, 'ok');
});
fs.createReadStream(zipPath)
.on('error', function (err) {
callback(err, null);
})
.pipe(unzipExtractor);
});
}
Http头
最近有个需求,需要在浏览器端下载zip文件。
于是就通过stream、pipe实现了此功能。
可是碰到了2个问题:
1.ie、firefox等浏览器下载的文件没有后缀名,下载下来后必须手动添加后缀。
2.下载的文件名错误,都是download,而不是实际我的压缩包文件。
经过大神提点,原来是要在返回的时候设置头部信息,指定文件的mime类型,以及文件名称才行。
下面以zip文件为例:
//设置mime类型
res.setHeader('Content-Type', 'application/zip');
//设置文件名
res.setHeader('Content-Disposition','attachment;filename=' + zipName + '.zip');
fs.createReadStream('xxx').pipe(res);
Node 文件上传,ZIP的更多相关文章
- node 文件上传
<!DOCTYPE html> <html> <head lang="en"> <meta charset="UTF-8&quo ...
- Node开发文件上传系统及向七牛云存储和亚马逊AWS S3的文件上传
背景起,有奏乐: 有伟人曰:学习技能的最好途径莫过于理论与实践相结合. 初学Node这货时,每每读教程必会Fall asleep. 当真要开发系统时,顿觉精神百倍,即便踩坑无数也不失斗志. 因为同团队 ...
- node.js 在 Express4.0 框架使用 Connect-Busboy 实现文件上传
node.js下四种post提交数据的方式 今天说分享的是其中一种,就是上传文件. Express 4.0 以后,将功能原子化,高内聚,低耦合,独立出了很多中间件 今天主要分享文件上传 对于conne ...
- node应用通过multer模块实现文件上传
multer用于处理文件上传的nodejs中间件,主要跟express框架搭配使用,只支持表单MIME编码为multipart/form-data类型的数据请求. 如果要处理其他编码的表单数据可以通过 ...
- Node.js新手教程——怎样实现文件上传功能
作者:zhanhailiang 日期:2014-11-16 本文将介绍怎样使用Node.js实现文件上传功能. 1. 初始化项目信息:npm init [root@~/wade/nodejs/node ...
- php上传zip文件在线解压文件在指定目录下,CI框架版本
我从网上找的文件php在线解压zip压缩文件 文件为jy.php可以直接执行,但是怎样将其加到CI框架中呢?? jy.php文件 <?php header("content-Type: ...
- node.js系列(实例):原生node.js+formidable模块实现简单的文件上传
/** * 原生node.js结合formidable模块实现图片上传改名 * @Author:Ghost * @Date:2016/07/15 * @description: * 1.引入模块htt ...
- node中间层实现文件上传
一般情况下,前端的文件上传一般都是通过form表单的(<input type="file" />)来完成文件的上传,如果使用node中间层完成跨域,文件的上传就需要在n ...
- node.js使用express框架进行文件上传
关于node.js使用express框架进行文件上传,主要来自于最近对Settings-Sync插件做的研究.目前的研究算是取得的比较好的进展.Settings-Sync中通过快捷键上传文件,其实主要 ...
随机推荐
- [转]iOS7 后台执行
[转自:http://esoftmobile.com/2013/06/23/ios7%E7%A8%8B%E5%BA%8F%E5%90%8E%E5%8F%B0%E8%BF%90%E8%A1%8C/] i ...
- 编译 Android 版本的 Opus 音频编解码库的方法
Opus 音频编解码库是 Speex 音频编解码库的下一代版本,从编解码性能以及质量上来讲都有了长足的进步.Opus 的编译非常简单,但是官方并未给出详细的 Android 版本编译指南,查找了大量资 ...
- LeetCode OJ--Path Sum II **
https://oj.leetcode.com/problems/path-sum-ii/ 树的深搜,从根到叶子,并记录符合条件的路径. 注意参数的传递,是否需要使用引用. #include < ...
- jquery小技巧:使用jquery.confirm和PNotify实现弹出提示和消息提示
在从UIKIT前端换到BOOSTRAP前端时,一些转换的技巧. https://myclabs.github.io/jquery.confirm/ http://sciactive.github.io ...
- HTML-loading动画1
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...
- JS快速上手-基础Javascript
1.1背景 1.1.1 ECMAScript与javascript ECMAScript是javascript的官方命名.因为java已经是一个商标.如今,一些早前收到过授权的公司,如Moailla, ...
- BZOJ2243 [SDOI2011]染色(树链剖分+线段树合并)
题目链接 BZOJ2243 树链剖分 $+$ 线段树 线段树每个节点维护$lc$, $rc$, $s$ $lc$代表该区间的最左端的颜色,$rc$代表该区间的最右端的颜色 $s$代表该区间的所有连续颜 ...
- FireDAC 出现Variable length column[*] overflow. Value length - [80], column maximum length
FireDAC 出现Variable length column[*] overflow. Value length - [80], column maximum length FireDAC的 TF ...
- 【ActiveMQ】2.spring Boot下使用ActiveMQ
在spring boot下使用ActiveMQ,需要一下几个条件 1.安装并启动了ActiveMQ,参考:http://www.cnblogs.com/sxdcgaq8080/p/7919489.ht ...
- 【Todo】各种语言里面的for循环 & loop
会的语言多了,不同语言的语法就会混淆.整理了一下. Java里面: 普通的for循环之外: 有以下格式: for (int x : intarr) { } JS里面: }; for (x in per ...