nodejs强大的改变uploadDir

时间:2012-07-25 03:20:07

标签: node.js express formidable

我有一个项目,我试图完成我想上传图像 我可以上传图片,但不能上传用于上传的目录

ok允许代码:

 app.post('/register',function(req,res) 
    {
var form = new formidable.IncomingForm();
form.keepExtensions = true;
form.uploadDir ='./uploaded/';
form
    .on('error', function(err) {
        throw err;
    })

    .on('field', function(field, value) {
        //receive form fields here
    })

    /* this is where the renaming happens */
    .on ('fileBegin', function(name, file){
            //rename the incoming file to the file's name
            file.path = form.uploadDir + "/" + file.name;
    })

    .on('file', function(field, file) {
        //On file received
    })

    .on('progress', function(bytesReceived, bytesExpected) {
        //self.emit('progess', bytesReceived, bytesExpected)

        var percent = (bytesReceived / bytesExpected * 100) | 0;
        process.stdout.write('Uploading: %' + percent + '\r');
    })

    .on('end', function() {


    });

form.parse(req);

问题是,当我发布图像时...图像仍然保存在process.env.TMP上 我的proyect有这个dir arq

proyect:
    node_modules
    uploaded
    public
    routes
    views
    app.js
    package.json

编辑2:问题是BODYPARSER

好的,从最后一个代码...问题是app.js,当我配置应用程序有一个bodyParser,以便bodyParser方法使用来自快递的强大的

最后一个代码是正确的和功能上的,如果有人想使用代码...只需注释来自express.configure的行

app.use(express.bodyParser());

关闭快递体操运动员但是表达使用强大也是同样的事情......

还有另一个问题

我像这样配置express.bodyParser

  app.use(express.bodyParser(
    {
      uploadDir: './uploads',
      keepExtensions: true
    }));

我改变了第一个这样的代码

app.post('/register',function(req,res) 
{
  var oldDir=req.files.img.path;
  var newDir='./uploads/'+req.body.email+'/perfil/';

if(req.files)
{
  mkdirp(newDir,0777,function(err){
    if(err) throw err;
  })
}
if(req.files)
{
  fs.rename(oldDir,newDir+req.files.img.name,function(err){
    if(err) throw err;
  });

}
res.send('pow!');

它是功能性的,当此代码接收文件时,将文件放在uploads文件夹中,然后使用电子邮件名称创建文件夹,最后将文件移动到电子邮件文件夹中,并将其重命名为带有扩展名的原始文件

完美的“!

nooo没有完美......我想用这种方法

.on ('fileBegin', function(name, file){
            //rename the incoming file to the file's name
            file.path = form.uploadDir + "/" + file.name;
    })
    .on('progress', function(bytesReceived, bytesExpected) {
        //self.emit('progess', bytesReceived, bytesExpected)

        var percent = (bytesReceived / bytesExpected * 100) | 0;
        process.stdout.write('Uploading: %' + percent + '\r');
    })

因为从第一个代码我可以配置从一开始放文件的位置 在第二个代码中,我在服务器收到文件后移动文件

我认为该方法是明确的,因为快速使用强大的中间件

如何在??

上配置方法

方法在哪里??'?

如何从第二个代码知道req.files中包含的方法? (因为使用bodyParser()的req.files与在第一个代码中使用formidable的form.file相同)

全部

2 个答案:

答案 0 :(得分:8)

IncomingForm构造函数接受一个options对象。您可能还需要在路径中使用__dirname全局。

var form = new formidable.IncomingForm({ uploadDir: __dirname + '/uploaded' });

您可以在formidable source中看到该选项的应用方式。

答案 1 :(得分:-2)

您可以在触发“结束”时保留重命名代码,以便在文件完全上传后重命名。