NodeJs错误:TypeError: Cannot read property 'path' of undefined

情景重现:

错误代码:

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) {
   
fs.renameSync(files.upload.path, "/tmp/test.png");
    response.writeHead(200, {"Content-Type": "text/html"});
    response.write("received image:
");
    response.write("");
    response.end();
  });
}

错误打印的日志代码:

/Users/wangwei/Desktop/nodeJs/requestHandlers.js:67

    fs.renameSync(files.upload.path, "/tmp/test.png");

                              ^

TypeError: Cannot read property 'path' of undefined

    at /Users/wangwei/Desktop/nodeJs/requestHandlers.js:67:31

    at IncomingForm. (/Users/wangwei/Desktop/nodeJs/node_modules/formidable/lib/incoming_form.js:102:9)

    at emitOne (events.js:96:13)

    at IncomingForm.emit (events.js:188:7)

    at IncomingForm._error (/Users/wangwei/Desktop/nodeJs/node_modules/formidable/lib/incoming_form.js:290:8)

    at IncomingMessage. (/Users/wangwei/Desktop/nodeJs/node_modules/formidable/lib/incoming_form.js:132:14)

    at emitNone (events.js:86:13)

    at IncomingMessage.emit (events.js:185:7)

    at endReadableNT (_stream_readable.js:926:12)

    at _combinedTickCallback (internal/process/next_tick.js:74:11)

问题原因:

红色的位置就是我在按照《nodeJs入门》那本书在做练习的时候遇到的错误。问题出现的原因是我在按照书中教程写代码的时候,server.js

中的代码没有注释(如下图)。在网上搜索了许久,终于在nodejs论坛找到了问题所在,贴下地址:http://cnodejs.org/topic/50234890f767cc9a51f88481

NodeJs错误:TypeError: Cannot read property 'path' of undefined_第1张图片

解决方案:把设置request编码的地方注释掉就可以了。

把问题贴出来,祝大家学习快乐。

你可能感兴趣的:(nodeJs)