5

几个月前,我发现了 nowjs 和 dnode,最后使用 nowjs(和https://github.com/Flotype/nowclient)进行客户端/服务器双向通信。

nowclient 在 2 个节点进程之间启用 nowjs 通信(而不是在一个节点进程和一个开箱即用的 nowjs 浏览器之间)。然后我能够将数据从客户端发送到服务器,然后从服务器发送到客户端。我现在使用节点 0.6.12,使用节点 0.4.x 运行客户端有点痛苦。

我正在仔细研究 dnode,但我不确定服务器到客户端的通信是如何工作的。服务器是否有可能向客户端发送直接消息?这个想法是让一个客户端在服务器上注册(在第一次连接时),并使服务器能够在需要时联系客户端。

据我了解,如果客户端首先从服务器请求某些内容,则可以在服务器上调用方法。那是对的吗 ?

4

1 回答 1

10

dnode 使用对称协议,因此任何一方都可以定义对方可以调用的函数。您可以采取两种基本方法。

第一种方法是在服务器端定义一个注册函数,并从客户端传入一个回调。

服务器:

var dnode = require('dnode');

dnode(function (remote, conn) {
    this.register = function (cb) {
        // now just call `cb` whenever you like!
        // you can call cb() with whichever arguments you like,
        // including other callbacks!

        setTimeout(function () {
            cb(55);
        }, 1337);
    };
}).listen(5000)

客户:

var dnode = require('dnode');

dnode.connect('localhost', 5000, function (remote, conn) {
    remote.register(function (x) {
        console.log('the server called me back with x=' + x);
    });
});

或者,一旦方法交换完成,您可以直接从服务器以对称方式调用客户端:

服务器:

var dnode = require('dnode');

dnode(function (remote, conn) {
    conn.on('ready', function () {
        remote.foo(55);
    });
}).listen(5000);

客户:

var dnode = require('dnode');
dnode(function (remote, conn) {
    this.foo = function (n) {
        console.log('the server called me back with n=' + n);
    };
}).connect('localhost', 5000);
于 2012-05-08T13:22:48.037 回答