用formidable处理上传的文件 并更改文件名
在Web开发中,文件上传也是一个非常常见、非常重要的功能。想象一下,你正要创建一个可以上传相册的程序,还要通过Web链接跟其他人分享你的照片。借助带文件上传控件的表单,用浏览器可以实现这个功能。formidable的流式解析器让它成为了处理文件上传的绝佳选择,也就是说它能随着数据块的上传接收它们,解析它们,并吐出特定的部分,就像我们之前提到的部分请求头和请求主体。这种方式不仅快,还不会因为需要大量缓冲而导致内存膨胀,即便像视频这种大型文件,也不会把进程压垮。
let http = require('http');
let formidable = require('formidable');
let util = require("util");
let fs = require("fs");
let sd = require("silly-datetime");
let path = require("path");
let server=http.createServer((req,res)=>{
console.log(req.method);
switch (req.method){
case 'GET':
show(req,res);
break;
case 'POST':
upload(req, res);
break;
}
})
server.listen(32001)
function show(req,res) {
//提供带有文件上传控件的HTML表单
let html=`
<html>
<body>
<form method="post" action="/" enctype="multipart/form-data">
<p><input type="text" name="name"></p>
<p><input type="file" name="file"></p>
<p><input type="submit" value="Upload"></p>
</form>
</body>
</html>
`
res.setHeader('Content-type', 'text/html');
res.setHeader('Content-Length', Buffer.byteLength(html));
res.end(html);
}
function upload(req,res) {
if (!isFormData(req)){
//在请求中的内容类型不对时返回400 Bad Request响应
res.statusCode = 400;
res.end('Bad Request');
return;
}
let form = new formidable.IncomingForm();
form.uploadDir = "./uploads";
form.on('field',(field,value)=>{
console.log(field);
console.log(value);
});
form.on('file',(name,file)=>{
console.log(name);
console.log(file);
});
form.on('end',()=>{
res.end('upload complete');
})
form.parse(req,(err,fields,files)=>{
//重命名
let ttt = sd.format(new Date(), 'YYYYMMDDHHmmss');
let ran = parseInt(Math.random() * 89999 + 10000);
let extname = path.extname(files.file.name);
let oldpath=__dirname+'/'+files.file.path
let newpath = __dirname + '/uploads/' + ttt + ran + extname;
fs.rename(oldpath, newpath,function(err){
if(err){
throw Error("改名失败");
}
});
});
}
//辅助函数isFormData()用String.indexOf()方法检查请求头中的Content-Type字段,断言它的值是以multipart/form-data开头的。
function isFormData(req) {
let type = req.headers['content-type'] || '';
return 0 === type.indexOf('multipart/form-data');
}