1. 程式人生 > >NodeJs錯誤:TypeError: Cannot read property 'path' of undefined

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:<br/>");
    response.write("<img src='/show' />");
    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.<anonymous> (/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.<anonymous> (/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


解決方案:把設定request編碼的地方註釋掉就可以了。

把問題貼出來,祝大家學習快樂。