在NodeJ中执行异步卷曲的最佳方式
Best way to do an asynchronous curl in NodeJs
我正在寻找一种从nodejs(确切地说,从服务器端到服务器端)获得异步请求的方法。最好的方法是什么(或者至少是一种方法)?
curl -H "accept:text/event-stream" http://api.example.com/createAccount
请注意,响应应该是异步的,并且看起来像这样:
event: status
id: 1
data: {"id":651,"country":{"code":"gt"},"service":{"slug":"something"},"state":"created"}
event: status
id: 2
data: {"id":651,"country":{"code":"gt"},"service":{"slug":"something"},"state_change":{"from":"reserved","to":"querying"}}
event: status
id: 3
data: {"id":651,"country":{"code":"gt"},"service":{"slug":"something"},"run_state_change":{"from":"idle","to":"busy"}}
event: status
id: 4
data: {"id":651,"country":{"code":"gt"},"service":{"slug":"something"},"state_change":{"from":"querying","to":"ready"}}
event: status
id: 5
data: {"id":651,"country":{"code":"gt"},"service":{"slug":"something"},"run_state_change":{"from":"busy","to":"idle"}}
event: result
id: 6
data: {"id":"651","state":"ready","url":"http://accounts.example.com/v1/services/accounts/651"}
然后我们完成了,我们有了ready
状态,服务器已经停止响应。
我已经尝试了一段时间,但我没有得到预期的结果,我尝试的一种方法是:
var EventSource = require('eventsource');
var es = new EventSource('http://api.example.com/createAccount');
es.onmessage = function(e) {
console.log(e.data);
};
es.onerror = function() {
console.log('ERROR!');
};
但是onmessage
方法似乎对我不起作用
我尝试了另一种方法,但结果总是一样请求等待,直到服务器完成,然后我得到结果
你能帮我做这个吗?
问题在于,您的事件是命名的,因此它们不会被默认的事件消息处理程序捕获(在浏览器实现中也会发生同样的情况,只是您使用浏览器的addEventListener()
API来侦听事件)。试试这个:
var es = new EventSource('http://api.example.com/createAccount');
es.on('status', function(e) {
// status event
console.log(e.data);
}).on('result', function(e) {
// result event
console.log(e.data);
}).on('error', function() {
console.log('ERROR!');
});
相关文章:
- 在localhost Dev Box上测试JSONP请求的最佳方式
- 为react组件传递道具的最佳方式
- 让Webpack管理Quirky AMD定义的最佳方式
- 在承诺链中处理早期回报的最佳方式
- 在ng重复循环中显示条件内容的最佳方式是什么
- 在phonegap中为android调用onload函数的最佳方式
- 链接两个网页或网络应用程序的最佳方式
- 什么's是连接供应商js文件的最佳方式
- 什么's是在javascript中迭代项的最佳方式
- 在node.js中编写单元测试的最佳方式是什么
- 在页面上记录数据并实现pushstate()的最佳方式
- 使用AJAX在Rails中提交动态表单的最佳方式是什么
- 什么'这是加载jQuery的最佳方式
- 将大数组(字符串和类型数组的混合物)存储到blob或文件中/从blob或文件检索大数组的最佳方式
- 在网站上显示.mov作为加载屏幕的最佳方式
- 使用Angular存储用户以前是否选中过复选框,然后再调用它的最佳方式是什么
- 以角度渲染表中数据的最佳方式
- 删除集合中旧邮件/帖子的最佳方式
- 显示全屏Ajax加载程序的最佳方式
- PHP和JS中表单验证的最佳方式