上传文件:

很多人会使用第三包进行文件的上传,例如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的更多相关文章

  1. node 文件上传

    <!DOCTYPE html> <html> <head lang="en"> <meta charset="UTF-8&quo ...

  2. Node开发文件上传系统及向七牛云存储和亚马逊AWS S3的文件上传

    背景起,有奏乐: 有伟人曰:学习技能的最好途径莫过于理论与实践相结合. 初学Node这货时,每每读教程必会Fall asleep. 当真要开发系统时,顿觉精神百倍,即便踩坑无数也不失斗志. 因为同团队 ...

  3. node.js 在 Express4.0 框架使用 Connect-Busboy 实现文件上传

    node.js下四种post提交数据的方式 今天说分享的是其中一种,就是上传文件. Express 4.0 以后,将功能原子化,高内聚,低耦合,独立出了很多中间件 今天主要分享文件上传 对于conne ...

  4. node应用通过multer模块实现文件上传

    multer用于处理文件上传的nodejs中间件,主要跟express框架搭配使用,只支持表单MIME编码为multipart/form-data类型的数据请求. 如果要处理其他编码的表单数据可以通过 ...

  5. Node.js新手教程——怎样实现文件上传功能

    作者:zhanhailiang 日期:2014-11-16 本文将介绍怎样使用Node.js实现文件上传功能. 1. 初始化项目信息:npm init [root@~/wade/nodejs/node ...

  6. php上传zip文件在线解压文件在指定目录下,CI框架版本

    我从网上找的文件php在线解压zip压缩文件 文件为jy.php可以直接执行,但是怎样将其加到CI框架中呢?? jy.php文件 <?php header("content-Type: ...

  7. node.js系列(实例):原生node.js+formidable模块实现简单的文件上传

    /** * 原生node.js结合formidable模块实现图片上传改名 * @Author:Ghost * @Date:2016/07/15 * @description: * 1.引入模块htt ...

  8. node中间层实现文件上传

    一般情况下,前端的文件上传一般都是通过form表单的(<input type="file" />)来完成文件的上传,如果使用node中间层完成跨域,文件的上传就需要在n ...

  9. node.js使用express框架进行文件上传

    关于node.js使用express框架进行文件上传,主要来自于最近对Settings-Sync插件做的研究.目前的研究算是取得的比较好的进展.Settings-Sync中通过快捷键上传文件,其实主要 ...

随机推荐

  1. HDU 6188最小费用流

    题目链接:http://hdu.hustoj.com/showproblem.php?pid=6118 掉坑里了,图很好建,Wa了一发,看了Disscuss里面有人提供了一组样例,画图发现:最小流模板 ...

  2. android中添加只有border-left的样式

    如何在android中的边框添加只有左边边框有颜色的样式呢 1. 相应的drawable文件 <?xml version="1.0" encoding="utf-8 ...

  3. Android Intent调用 Uri的使用几种格式

    打开百度 Uri uri = Uri.parse("http://www.baidu.com"); Intent intent =new Intent(Intent.ACTION_ ...

  4. tensorflow搭建神经网络基本流程

    定义添加神经层的函数 1.训练的数据2.定义节点准备接收数据3.定义神经层:隐藏层和预测层4.定义 loss 表达式5.选择 optimizer 使 loss 达到最小 然后对所有变量进行初始化,通过 ...

  5. angular - 小结

    引入样式: 导入全局 - >styles.css 导入第三方 - > 在package.json配置,然后再 npm install 安装好以后,最后再angular.json里面的sty ...

  6. PC和手机怎么实现绝对居中?

    示例1(懒人之家): http://www.51xuediannao.com/js/nav/360buy_nav.html 示例2(google官方):

  7. 使用正則表達式对URL进行解析

    对URL进行解析,一般用到的參数有: 1.协议 如http,https 2.域名或IP 3.port号,如7001,8080 4.Web上下文 5.URI.请求资源地址 6.请求參数 一个URL演示样 ...

  8. basePath 方便

    String path = request.getContextPath()+"/";String basePath = request.getScheme() + ": ...

  9. sparkSQL1.1入门之十:总结

    回想一下,在前面几章中,就sparkSQL1.1.0基本概念.执行架构.基本操作和有用工具做了基本介绍. 基本概念: SchemaRDD Rule Tree LogicPlan Parser Anal ...

  10. Solaris 目录与文件管理

    熟悉系统目录结构 掌握27个常用命令 掌握针对目录.文件的操作 掌握查找与文件内容的操作 一.命令 命令:内部命令(不依赖其他文件,可以直接执行)与外部命令 .他是用于实现某一类功能的指令或程序,其执 ...