我在node.js和express中创建一个REST API。它与远程HANA数据库连接&执行一个查询。现在,我想流式http响应,以便可以将其发送到浏览器中,而不是完全发送它,因为它是一个很大的数据。
我尝试了一些没有输出的东西。我不知道原因。如果我使用响应(数据)将完整的响应发送给浏览器,则可以正常工作。但是流媒体现在正在起作用。
我在下面添加了代码段。
const express = require("express");
const APP = express();
const HANA_DB = require('hdb');
const BODY_PARSER = require("body-parser");
start();
function start() {
startServer();
initializeExpress();
APP.get("/data", function(request, response) {
var connection = HANA_DB.createClient({
host : "hostname",
port : "port",
user : "username",
password : "password"
});
connection.on('error', function (error) {
console.log("Error in database connection...");
});
connection.connect(function (error) {
if (error) {
console.log("Error in database connection...");
return;
}
var query = "SELECT * FROM TableName";
connection.exec(query, function(error, result) {
if(error) {
response.send("Getting error while fetching result...");
return;
}
//response.send(data);
var datalength = 0;
request.on('data', function(chunk) {
datalength += chunk.length;
console.log("DATA EVENT: " + datalength);
response.send(datalength);
})
.on('end', function() {
console.log("END EVENT: " + datalength);
response.send(datalength);
});
});
});
});
};
function initializeExpress() {
APP.all('/*', function(request, response, next) {
response.header("Access-Control-Allow-Origin", "*");
response.header("Access-Control-Allow-Headers", "X-Requested-With");
response.header('Access-Control-Allow-Methods', 'PUT, GET, POST, DELETE, OPTIONS');
response.header('Access-Control-Allow-Headers', 'Content-Type');
next();
});
APP.use(BODY_PARSER.json());
APP.use(BODY_PARSER.urlencoded({ extended: true }));
};
function startServer(config) {
var server = APP.listen("8081", function(error) {
if(error) {
console.log("Unable to connect to 127.0.0.1:8081");
return;
}
console.log("Server is listening at - 127.0.0.1:8081");
});
};
我认为您使用的逻辑是流式传输数据的错误。
使用 res.write 代替 res.send ,您还必须从数据库中读取流数据,而不是一次 connection.exec
我为您提供了一个示例代码,您将在Expressjs中获得有关流数据的一些想法。
var http = require( 'http' );
http.createServer( function ( req, res ) {
res.writeHead( 200, {
'Content-Type': 'text/plain; charset=utf-8',
'Transfer-Encoding': 'chunked',
'X-Content-Type-Options': 'nosniff'
} );
res.write( 'Beginningn' );
var count = 10;
var io = setInterval( function () {
res.write( 'Doing ' + count.toString() + 'n' );
count--;
if ( count === 0 ) {
res.end( 'Finishedn' );
clearInterval( io );
}
}, 1000 );
} ).listen( 8000 );
问题在这里request.on('data',
。request
指的是浏览器请求。
您不能与.exec()
一起使用流媒体,因为exec
的回调函数以参数为参数。
要使用流媒体,使用.execute()
方法,该方法将结果集传递给回调函数。
我从未使用过 hdb
,所以我不能使用代码使用。