【发布时间】:2015-03-01 23:14:13
【问题描述】:
我正在构建一个 web 服务,为此我使用 nodejs、phantomjs 和 expressjs。这三个我都在学习。
我想在处理客户的查询后向他们提供延迟响应。比如,
我正在处理来自我的客户的某些输入,然后,我想在后端处理数据,平均需要大约 10 秒。然后我想将此页面提供给客户。
是否可以在节点中对同一个请求发送多个响应或延迟响应,以便模板自动更新内容。
或者,我是否应该使用相同的方法,例如将 json 存储在服务器中的文件中,然后使用 ajax 提供页面,该页面将查询页面。
请帮助我。这是我写的代码,
app-server.js(主文件):
// import express module
var express = require('express');
var bodyParser = require('body-parser');
var app = express();
// define all required template files to be served and also define the template engine
app.engine('.html', require('ejs').__express);
app.set('views', __dirname + '/views');
app.set('view engine', 'html');
// Useful modules
app.use(bodyParser.json());
app.use(bodyParser.urlencoded({extended: true}));
// import the routes
require('./router')(app);
app.listen(8080);
router.js:
var crypto = require('crypto');
var express = require('express');
module.exports = function (app) {
// define the static routes.
app.use('/static', express.static('./static'));
app.use('/media', express.static('./media'));
//defining the controller.
var parserlib = require('./controller.js')
// Define the home root path
app.get('/', function (req, res) {
// shows the home search page.
res.render('index', {content:'template success'});
});
app.get('/search', function(req, res){
res.redirect('/');
});
app.post('/search', parserlib.parserlib);
}
controller.js:
var crypto = require('crypto');
var path = require('path')
var childProcess = require('child_process')
exports.parserlib= function(req, res){
var output = '';
var url = req.body.search_url;
var childArgs = [
path.join(__dirname, 'external-script.js'),
url,
]
// execute the script in a separate thread.
childProcess.execFile(binPath, childArgs, function(err, stdout, stderr) {
// handle results
console.log(stdout);
output = stdout;
//console.log(err);
//res.send(output);
});
//res.send(output);
};
所以,我想看到的是,首先向客户端发送一个响应,说明它正在加载,然后我想用处理后的数据更新。在其他语言中,它不可能发送多个响应。不确定nodejs。
另外,我是否必须将处理后的库中的 json 输出存储到文件中,然后使用 ajax 进行查询?或者是否可以直接将json对象更新到客户端?
谢谢
【问题讨论】:
标签: javascript jquery ajax json node.js