2014-09-03 7 views
2

Я пытаюсь загрузить файл с использованием грозного, следуя учебнику в Node Beginner Book. После этого кода у меня есть серверные модули, которые передают объект request запросу requestHandler . модуль главная страница загружает форму со следующим обработчиком:Исключительная загрузка не работает: «файлы» undefined, no error

function start(response) { 
    console.log("Request handler 'start' was called."); 

    var body = '<html>'+ 
     '<head>'+ 
     '<meta http-equiv="Content-Type" content="text/html"; '+ 
     'charset=UTF-8" />'+ 
     '</head>'+ 
     '<body>'+ 
     '<form action="/upload" enctype="multipart/form-data method="post">'+ 
     '<input type="file" name="upload" multiple="multiple"'+ 
     '<input type="submit" value="Upload file" />'+ 
     '</form>'+ 
     '</body>'+ 
     '</html>'; 

    response.writeHead(200, {"Content-Type": "text/html"}); 
    response.write(body); 
    response.end(); 

} 

Когда форма отправлена, путь,/загрузки запускает следующую функцию обработчика загрузки:

function upload(response,request) { 
    console.log("Request handler 'upload' was called."); 

    var form = new formidable.IncomingForm(); 
    console.log("about to parse"); 
    form.parse(request, function(error, fields, files) { 
     console.log("parsing done"); 

     console.log(util.inspect({error: error, fields: fields, files: files})); 

     fs.rename(files.upload.path, "/tmp/test.png", function(error) { 
      if (error) { 
       console.log(error); 
       fs.unlink("/tmp/test.png"); 
       fs.rename(files.upload.path, "/tmp/test.png"); 
      } 
     }); 
     response.writeHead(200, {"Content-Type": "text/html"}); 
     response.write("received image:<br/>"); 
     response.write("<img src='/show' />"); 
     reponse.end(); 
    }); 

} 

Когда кнопка загрузки нажата , h owever, сервер падает со следующей ошибкой:

/home/****/Coding/nodebeginner/requestHandlers.js:38 
     fs.rename(files.upload.path, "/tmp/test.png", function(erro 
          ^
TypeError: Cannot read property 'path' of undefined 
    at /home/****/Coding/nodebeginner/requestHandlers.js:38:25 
    at IncomingForm.<anonymous> (/home/****/Coding/nodebeginner/node_modules/formidable/lib/incoming_form.js:104:9) 
    at IncomingForm.EventEmitter.emit (events.js:92:17) 
    at IncomingForm._maybeEnd (/home/****/Coding/nodebeginner/node_modules/formidable/lib/incoming_form.js:551:8) 
    at Object.end (/home/****/Coding/nodebeginner/node_modules/formidable/lib/incoming_form.js:238:12) 
    at IncomingMessage.<anonymous> (/home/****/Coding/nodebeginner/node_modules/formidable/lib/incoming_form.js:129:30) 
    at IncomingMessage.EventEmitter.emit (events.js:92:17) 
    at _stream_readable.js:920:16 
    at process._tickCallback (node.js:415:13) 

Так, очевидно, переменная files не определен. Я думал, что может быть ошибка, но нет значения error переменной null. Так что я немного здесь. Идеи?

+0

Какой серверный модуль вы используете? Как правило, или, по крайней мере, в стандартном 'createServer' и в Express.js, порядок параметров -' request, response', поэтому, возможно, это 'undefined', потому что' upload (response, request) '* должен быть *' upload (request , ответ) '? Также вам не хватает конечной цитаты после 'multipart/form-data' – Lasse

+0

Теперь я получаю новую ошибку: /home/ethan/Coding/nodebeginner/node_modules/formidable/lib/incoming_form.js:301 if (это.headers ['content-length']) { ^ ТипError: Невозможно прочитать свойство 'content-length' of undefined – fraxture

+0

Вы смогли его исправить? Я делаю то же учебное пособие и имею ту же проблему. – Carlo

ответ

1

У меня тоже такая проблема. Ваша форма тег отсутствует закрывающий двойные кавычки (") на атрибут ENCTYPE.

+1

Я думаю, что это правильный ответ - я получал ту же ошибку в этом учебнике; Оказывается, у меня также была опечатка в моих данных формы: «multipart-form-date» вместо «multipart-form-data». Для этого я решил проблему. Я вижу еще одну опечатку в фрагменте кода вопроса: первый <ввод отсутствует закрытие /> – Chad

2

У меня была такая же проблема. Я думаю, что вы видите эти строки кода на узле Beginner книги, в конце книги. я установил его путем удаленного наблюдения кода на server.js файла:

//  req.setEncoding("utf8"); 
//  req.addListener("data", function(postDataChunk) { 
//   postData += postDataChunk; 
//  }); 
//  req.addListener("end", function() { 
//   route(handle, pathname, res, req); 
//  }); 
Just do: 

route(handle, pathname, res, req);

And last, you must be careful at html form tags. 

Sorry for my English and best wishes! 

***VinRover Nguyen*** 
0

Я застрял в этом вопросе звучит как класс загрузки. были заменены или орфографированы. Попробуйте изменить ссылку с files.upload.path на files.Upload.path. Он работает здесь. Для получения дополнительной информации обратитесь к главному ответвлению: Git

0

Похоже, что у вас есть некоторые ошибки в вашем «корпусе var». Try:

var body = '<html>' + 
    '<head>' + 
    '<meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />' + 
    '</head>' + 
    '<body>' + 
    '<form action="/upload" enctype="multipart/form-data" method="post">' + 
    '<input type="file" name="upload" multiple="multiple">' + 
    '<input type="submit" value="Upload File">' + 
    '</form>' + 
    '</bidy>' + 
    '</html>'; 
0

Существует ошибка в названиях параметров для обратного вызова в form.parse.

Узел для начинающих Книга показывает код, как:

form.parse(request, function(error, fields, files) { 
    //code 
} 

параметры не должны быть во множественном числе в функции обратного вызова:

form.parse(request, function(error, field, file) { 
    //code 
} 

Взгляните на IncomingForm.prototype.parse в/node_modlues /formidable/lib/incoming_form.js. Обратный вызов прослушивает единственное «поле» и «файл».