`
lxs647
  • 浏览: 523087 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

NodeJS: 一行代码引发的杯具

 
阅读更多

这几天有点儿小空,寻思着看看Node JS 方面的东东。

在网上东搜搜西搜搜,找到如下网站:

http://www.nodebeginner.org/index-zh-cn.html

 

主题是node 入门。

 

于是乎就照着上面的代码敲下来, 一路行来倒是没有怎么遇到困难。

 

唯独最后在引入fs 模块和 formidable模块尝试完成文件上传功能时,出问题了。

 

报错如下:

 

 fs.renameSync(files.upload.path, "C:/sap/java/nodejs/examples/testUpload/test.png"

                             ^                     

TypeError: Cannot read property 'path' of undefined

    at c:\sap\java\nodejs\examples\hello\requestHandlers.js:30:30

    at IncomingForm.<anonymous> (c:\sap\java\nodejs\examples\hello\node_modules\

formidable\lib\incoming_form.js:89:9)

    at IncomingForm.EventEmitter.emit (events.js:95:17)

    at IncomingForm._error (c:\sap\java\nodejs\examples\hello\node_modules\formi

dable\lib\incoming_form.js:272:8)

    at IncomingMessage.<anonymous> (c:\sap\java\nodejs\examples\hello\node_modul

es\formidable\lib\incoming_form.js:119:14)

    at IncomingMessage.EventEmitter.emit (events.js:92:17)

    at _stream_readable.js:920:16

    at process._tickCallback (node.js:415:13)

 

我的代码如下

 

server.js

var http = require("http");

var url = require("url");

//var formidable = require("formidable");

 

function start(route,handle) {

http.createServer(function(request, response){

var postData="";

var pathName = url.parse(request.url).pathname;

console.log("Request for " + pathName + " received");

request.setEncoding("utf8");

route(handle, pathName, response, request);

}).listen(8081);

console.log("Server has started");

}

 

exports.start = start;

 

requestHandlers.js:

 

var queryString = require("querystring");

var formidable = require("formidable");

var fs = require("fs");

function start(response, request) {

console.log("Request handler 'start' is called");

 

var content = '<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"/>' +

'<input type="submit" value="Upload file" />' +

'</form>' +

'</body>' +

'</html>';

response.writeHead(200,{"Content-Type": "Text/html"});

response.write(content);

response.end();

}

 

function upload(response, request) {

console.log("Request handler 'upload' is called");

var form = new formidable.IncomingForm();

console.log("About to parse");

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

console.log("parse done");

//try{

fs.renameSync(files.upload.path, "C:/sap/java/nodejs/examples/testUpload/test.png");

/*}catch(e){

console.log(e);

}*/

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

response.write("received image:<br/>");

response.write("<image src='/show' />");

response.end();

});

}

 

function show(response, request) {

console.log("Requset handler 'show' is called");

fs.readFile("C:/sap/java/nodejs/examples/testUpload/test.png", "binary", function(error, file) {

if(error) {

response.writeHead(500, {"Content-Type": "text/plain"});

response.write(error + "\n");

response.end();

}else{

response.writeHead(200, {"Content-Type": "image/png"});

response.write(file, "binary");

response.end();

}

});

}

 

exports.start = start;

exports.upload = upload;

exports.show = show;

 

 

route.js:

 function route(handle, pathName, response, request) {

console.log("About to route a request for " + pathName);

 

if(typeof(handle[pathName])==='function'){

return handle[pathName](response, request);

}else{

console.log("No request handler found for " + pathName);

response.writeHead(404,{"Content-Type": "Text/Plain"});

response.write("404 Not Found");

response.end();

}

}

 

exports.route = route;

 

 

index.js:

var server = require("./server.js");

var route = require("./router.js");

var requestHandlers = require("./requestHandlers.js");

 

var handle = {};

 

handle['/'] = requestHandlers.start;

handle['/start'] = requestHandlers.start;

handle['/upload'] = requestHandlers.upload;

handle['/show'] = requestHandlers.show;

 

 

server.start(route.route, handle);

 

 

 看到server.js中的红色高亮的那一行,去掉就一切OK了。。。

 

因为request.setEncoding 这部分node-formidable自身会处理,在这个地方手动给设置一下貌似会有冲突,从而导致出错。

 

另外,值得注意的两点,在requestHandlers.js中,

1.由于我的开发环境是:win7 64, 在fs.parse 和 fs.readFile的路径参数中,我都是直接给出的是绝对路径。

  相对路径没有试过。

2.对应路径下的文件夹必须要存在(fs.renameSync 和 fs.readFile不会自动创建文件夹),否则还是会报错如下:

  fs.js:543

  return binding.rename(pathModule._makeLong(oldPath),

                 ^

Error: ENOENT, no such file or directory 'X:\...\ddcdf999d6b56cb30716f43e528e7eeb'

    at Object.fs.renameSync (fs.js:543:18)

    at c:\sap\java\nodejs\examples\hello\requestHandlers.js:30:7

    at IncomingForm.<anonymous> (c:\sap\java\nodejs\examples\hello\node_modules\

formidable\lib\incoming_form.js:92:9)

    at IncomingForm.EventEmitter.emit (events.js:92:17)

    at IncomingForm._maybeEnd (c:\sap\java\nodejs\examples\hello\node_modules\fo

rmidable\lib\incoming_form.js:533:8)

    at c:\sap\java\nodejs\examples\hello\node_modules\formidable\lib\incoming_fo

rm.js:211:12

    at WriteStream.<anonymous> (c:\sap\java\nodejs\examples\hello\node_modules\f

ormidable\lib\file.js:70:5)

    at WriteStream.g (events.js:175:14)

    at WriteStream.EventEmitter.emit (events.js:117:20)

 

    at finishMaybe (_stream_writable.js:354:12)

 

 

 

貌似有不少新人在做这个例子的时候都遇到了类似的问题, 如下两个网站中的楼主貌似也都是类似的问题:

http://cnodejs.org/topic/50234890f767cc9a51f88481

http://cnodejs.org/topic/4f2b9a04aa8e490b110bfae2

分享到:
评论

相关推荐

    nodejs:NodeJS示例项目

    节点js NodeJS示例项目

    flameddd#blog#2019-09-11:nodejs:functions 批次新增 document 到 collec

    nodejs:functions 批次新增 document 到 collections 裡面nodejs how functions to create do

    NodeJS:NodeJS视频教程源代码

    "NodeJS:NodeJS视频教程源代码"这个资源很可能是某个NodeJS教学视频的配套源代码,帮助学习者通过实际操作来深入理解NodeJS的编程原理和实践技巧。 在NodeJS中,我们主要会接触到以下几个关键知识点: 1. **非阻塞...

    aliyun-iot-demo-nodejs:Nodejs模拟硬件设备接入阿里云IoT物联网套件,基础版demo+高级版demo

    思路:温湿度计通过MQTT协议连接到IoT套件,规则引擎针对数据上报Topic配置转发到函数计算(FunctionComputer)中编写好的函数pushData2DingTalk,函数Nodejs脚本处理数据,post到钉钉群机器人的Webhook,配置了温湿度...

    NodeJS学习笔记和代码

    NodeJS是一种基于Chrome V8引擎的JavaScript运行环境,它允许开发者在服务器端使用JavaScript进行编程。这个"NodeJS学习笔记和代码"的压缩包显然包含了帮助初学者掌握NodeJS基础知识和实践技能的所有必要资料。 ...

    小程序源码 明星图(含NODEJS后端) (代码源)

    小程序源码 明星图(含NODEJS后端) (代码源)小程序源码 明星图(含NODEJS后端) (代码源)小程序源码 明星图(含NODEJS后端) (代码源)小程序源码 明星图(含NODEJS后端) (代码源)小程序源码 明星图(含NODEJS后端...

    Awesome-NodeJS:精选的NodeJS资源精选:writing_hand:

    名称 路线 资源 / :two_hearts: 很棒的NodeJS :two_hearts: ... x2-与NPM一起发布的模块集合,旨在提供一个完整的工具集,用于创建暴露RESTful API并由SQL数据库支持的后端应用程序。 TotalJS Moleculer微服务

    openwhisk-runtime-nodejs:Apache OpenWhisk运行时NodeJS支持用JavaScript为NodeJS编写的Apache OpenWhisk函数

    构建系统会生成以下Node.js运行时版本(带有种类和图像标签): Node.js 10.23.0( nodejs:10 & openwhisk/action-nodejs-v10 ) Node.js 12.19.1( nodejs:12 & openwhisk/action-nodejs-v12 ) Node.js 14.15.1...

    blogger_nodejs:Blogger分配2代码路径nodejs

    blogger_nodejs Blogger分配2代码路径nodejs

    nodejs实现统计项目代码行数的代码资源

    nodejs代码资源,主要用于统计前端项目中的代码行数、空行行数、注释行数、以及注释率,可通过目录或文件以及文件格式进行过滤筛选,统计出想要的代码文件的行数。 资源代码非常简单方便,代码清晰明了,注释也很...

    nodejs:Node.js食谱的开发存储库

    安装node.js / npm,并包括用于管理npm软件包的资源 要求 平台类 Debian / Ubuntu RHEL / CentOS /科学/亚马逊/ Oracle openSUSE 视窗 注意:源代码安装需要GCC 4.8+,较...include_recipe "nodejs::nodejs_from_pac

    inspector-nodejs:NodeJs应用程序的代码执行监视

    检验员代码执行监视工具为NodeJs开发人员构建的简单代码执行监视。安装通过以下方式安装最新版本: npm install @inspector-apm/inspector-nodejs --save配置提取密钥您需要一个Ingestion Key才能创建一个Inspector...

    nodejs:用于Nim的NodeJS标准库

    "nodejs:用于Nim的NodeJS标准库"这个项目的目标是为Nim提供一个接口,使其能够无缝地与Node.js生态系统交互,包括使用Node.js的模块和API。 **Nim与Node.js集成的优势** 1. **多语言融合**:Nim的高性能和Node.js...

    nodejs:NodeJS示例

    这个"nodejs:NodeJS示例"很可能是提供了一系列的NodeJS代码实例,帮助学习者理解和掌握NodeJS的基本用法和特性。下面,我们将详细讨论NodeJS的关键知识点。 1. **事件驱动编程**: NodeJS的核心设计是基于事件循环...

    curso-nodejs:treinamento nodejs

    【标题】:“curso-nodejs:treinamento nodejs”是一个关于Node.js的培训课程,它旨在教授用户如何使用Node.js这一强大的JavaScript后端运行时环境。Node.js利用Chrome的V8引擎,允许开发者在服务器端运行...

    nodeJS:NodeJS的当前存储库

    这个"nodeJS:NodeJS的当前存储库"可能指的是一个包含最新版本或开发中的NodeJS源代码、文档或者相关项目的存储库。下面将详细讨论NodeJS的主要特点、核心模块、常用工具以及在开发中的应用。 1. **NodeJS的特点** ...

    NodeJS:课程NodeJS

    编程语言: JavaScript NodeJS v11.10.1 集成开发环境(IDE): Visual Studio代码( ) Web应用程序服务器: 表达数据库: MongoDB(NoSQL)使用MongoDB的Crud NodeJS (第二部分-带Mongo DB的Crud NodeJS) Versi...

    nodejs:NodeJS相关内容集合

    由 Sten Hougaard 创建的这个内容集合,旨在为开发者提供一系列常用和实用的 NodeJS 代码片段,帮助大家在开发过程中避免重复劳动,提高效率。 ### NodeJS 基础概念 1. **事件驱动**:NodeJS 采用非阻塞 I/O 模型...

    profiling-nodejs::milky_way:高效地概要分析Node.js的文章和工具集合

    profiling-nodejs::milky_way:高效地概要分析Node.js的文章和工具集合

    TP_nodejs:Ynov B3C

    TP_nodejs:Ynov B3C

Global site tag (gtag.js) - Google Analytics