我有一个项目,我试图完成我想上传图像 我可以上传图片,但不能上传用于上传的目录
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相同)
全部
答案 0 :(得分:8)
IncomingForm构造函数接受一个options对象。您可能还需要在路径中使用__dirname全局。
var form = new formidable.IncomingForm({ uploadDir: __dirname + '/uploaded' });
您可以在formidable source中看到该选项的应用方式。
答案 1 :(得分:-2)
您可以在触发“结束”时保留重命名代码,以便在文件完全上传后重命名。