"use strict";
var multiparty = require('multiparty');
var util = require('util');
var fs = require('fs');
var path = require('path');
var _ = require('lodash');
var moment = require('moment');
//上传文件
exports.upload = function(req, res) {
console.log("upload");
//生成multiparty对象,并配置上传目标路劲
//通过__dirname获取当前模块的路径,然后拼接上传路径
var uploadPath = path.join(__dirname, '../upload/');
//判断是否存在upload文件夹,不存在就创建一个
var pathIsExist = createDir(uploadPath);
// 在此项目下创建一层目录
function createDir(dirpath) {
if(!fs.existsSync(dirpath)) {
var isExist = fs.mkdirSync(dirpath);
if(!isExist) {
return fs.existsSync(dirpath);
}
}
return true;
}
if(!pathIsExist) {
//return res.status(200).json({success : false, msg : "文件上传失败"});
return res.send("0");
}
//文件上传,上传目录为upLoadPath
var form = new multiparty.Form({uploadDir : uploadPath});
//上传完成后处理
form.parse(req, function(err, fields, files) {
var filesTmp = JSON.stringify(files,null,2);
if(err || (_.isEmpty(fields) && _.isEmpty(files))) {
//return res.json({success : false, msg : "上传失败!"});
return res.send("0");
}
var inputFile = files.file[0];
var uploadedPath = inputFile.path;
var filenameArr = inputFile.originalFilename.split(".");
var suffixName = filenameArr.pop();
var newName = filenameArr.join("") + moment().format('YYYYMMDDHHmmss') + "." + suffixName;
var dstPath = uploadPath + newName;
//重命名为真实文件名
fs.rename(uploadedPath, dstPath, function(err) {
if(err){
console.log('rename error: ' + err);
} else {
console.log('rename ok');
//res.status(200).json({success : true, msg : "上传成功!", filesMsg : filesTmp});
return res.send("1");
}
});
});
};
总结:
以上实现的功能主要用到以下知识点:
1.path.join([...paths])
参数:
...paths <string> 一个路径片段的序列
返回: <string>
path.join() 方法使用平台特定的分隔符把全部给定的 path 片段连接到一起,并规范化生成的路径。
长度为零的 path 片段会被忽略。 如果连接后的路径字符串是一个长度为零的字符串,则返回 '.',表示当前工作目录。
例子:
path.join('/foo', 'bar', 'baz/asdf');
// 返回: '/foo/bar/baz/asdf'
2.fs.existsSync(dirpath)
fs.exists() 的同步版本。 如果文件存在,则返回 true,否则返回 false。
3.multiparty的使用:
[multiparty的详细使用](https://www.npmjs.com/package/multiparty)