用formidable处理上传的文件 并更改文件名

用formidable处理上传的文件 并更改文件名

用formidable处理上传的文件 并更改文件名_第1张图片
image.png

在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=`


 

` 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'); }

你可能感兴趣的:(用formidable处理上传的文件 并更改文件名)