我正在尝试使用Nodejs创建一个REST JSON,但是当我尝试编写时,它会让我错误,任何人都可以帮忙吗?
var oracle = require ( 'oracle' ) ;
var http = require ( 'http' ) ;
var url = require ('url');
var port = 80 ;
var testarray = [];
var cnnString = {
hostname : 'xxx.xxx.xxx.xxx',
port : xxxxx,
database : 'xxxxxxxxxx.com' ,
user : 'xxxxx' ,
password : 'xxxxxx'
} ;
oracle.connect ( cnnString, countrylist ) ;
function countrylist( err, connection ) {
var reader = connection.reader("select distinct company_code, company_name from mbl_employee_v order by company_code", []);
function doRead(cb) {
reader.nextRow(function(err, row) {
if (err) return cb(err);
if (row) {
// do something with row
testarray.push(JSON.stringify(row));
return doRead(cb)
} else {
// we are done
return cb();
}
})
}
doRead(function(err) {
if (err) throw err; // or log it
console.log("all records processed");
// console.log(testarray);
});
}
var app = http.createServer ( cb ) ;
app.listen ( port , function () {
console.log ( 'Http server listening at port : ' + port ) ;
} ) ;
function cb ( req, res ) {
var QueryVal = url.parse(req.url,true);
res.writeHead ( 200 , { 'Content-Type' : 'application/json' } ) ;
switch ( QueryVal.pathname ) {
case '/' :
res.write ( "Hello, World" ) ;
break ;
case '/about' :
console.log(testarray);
res.write (testarray) ;
break ;
case '/product' :
res.write ( 'product' ) ;
break ;
default :
res.write ( 'unknow' ) ;
break ;
}
res.end ( '' ) ;
} ;
这里我的console.log显示了数据,但是res.write给了我错误
http.js:851 抛出新的TypeError('第一个参数必须是字符串或缓冲区'); ^ TypeError:第一个参数必须是字符串或缓冲区
- at ServerResponse.OutgoingMessage.write(http.js:851:11)
- at Server.cb(/opt/Nodejs/ex05-readData01.js:65:7)
- 在Server.emit(events.js:98:17)
- at HTTPParser.parser.onIncoming(http.js:2108:12)
- 在HTTPParser.parserOnHeadersComplete [as onHeadersComplete](http.js:121:23)
- at Socket.socket.ondata(http.js:1966:22)
- at TCP.onread(net.js:527:27)
答案 0 :(得分:2)
这样做
res.write(JSON.stringify(testArray));
而不是
res.write(testArray);
因为write
函数将String或Buffer作为参数,并且您传递的是数组。