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编码的地方注释掉就可以了。

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

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值