socket.io发出后在浏览器中回调

时间:2014-10-03 18:58:04

标签: javascript php node.js callback socket.io

我正在开发一种方法来在浏览器页面中获取回调,然后发送到socketio服务器。

服务器代码:

/** exec php file and retrieve the stdout */
socket.on('php', function(func, uid, data) {
    console.log('php'.green + ' act:' + func + ' uid:' + uid);
    runner.exec("php " + php_[func].exec,
    function(err, stdout, stderr) { 
        if (err == null) {
            socket.emit('php', {uid: uid, o: stdout});
            console.log('emitted');
        } else {
            console.log('err '.red + stdout + ' ' + stderr);
        }
    });
});

此代码执行php页面并检索输出以在浏览器中显示或解析 它收到一个回显到页面的id,所以我可以知道要执行什么功能

执行回调的浏览器代码:

    function log(text) {
        $('.out').append(text + '<br />');
    }
    window.callbacks = [];

    function setcb(c) {
        var max = 0;
        $.each(window.callbacks, function(index) {max = (index > max ? index : max);});
        window.callbacks[max+1] = c;
        return max+1;
    };
    function C(k){return(document.cookie.match('(^|; )'+k+'=([^;]*)')||0)[2]}

    var s = io.connect("http://"+ window.location.host +":8088");
    //s.emit('debug', 'here');
    s.on('getid', function(){
        console.log('getid cookieis: ' + C('igr') );
        s.emit('setid', C('igr'));
    });


    s.emit('php', 'test',
        setcb(
            function () {
                var data = JSON.parse(this);
                log('callback passed' + this);
            }
        ), null
    );

    s.on('php', function(data) {
        //window.callbacks[j.uid].call(j.o);
        log('rec' + JSON.stringify(data));
        //var jsn = JSON.parse(data);
        console.log(data);
        console.log(window.callbacks[data.uid]);
        window.callbacks[data.uid].call(data.o);
        delete window.callbacks[data.uid];
        window.callbacks.splice(data.uid, 1);
        console.log(window.callbacks);
    });

这是有效的,但是当我尝试同时发出两个请求时,它不会像预期的那样运行,只留下一个回调执行并在回调数组中。

测试代码:

    s.emit('php', 'test',
        setcb(
            function (data) {log('callback passed' + this);}
        ), null
    );
    s.emit('php', 'test',
        setcb(
            function (data) {log('callback passed' + this);}
        ), null
    );

我想消除此错误,并且对于收到的每个事件,执行我定义的回调。

1 个答案:

答案 0 :(得分:0)

这比我想象的更简单 您可以通过引用传递回调。 服务器端代码:

/** exec php file and retrieve the stdout */
socket.on('php', function(func, data, callback) {
    console.log('php'.green + ' act:' + func);
    runner.exec("php " + php_[func].exec,
    function(err, stdout, stderr) { 
        if (err == null) { 
            callback(stdout);
            //socket.emit('php', {uid: uid, o: stdout});
            console.log('emitted');
        } else {
            console.log('err '.red + stdout + ' ' + stderr);
        }
    });
});

客户端代码:

    function log(text) {
        $('.out').append(text + '<br />');
    }
    function C(k){return(document.cookie.match('(^|; )'+k+'=([^;]*)')||0)[2]}

    var s = io.connect("http://"+ window.location.host +":8088");
    //s.emit('debug', 'here');
    s.on('getid', function(){
        console.log('getid cookieis: ' + C('igr') );
        s.emit('setid', C('igr'));
    });


    s.emit('php', 'test', null,
        function(data) { log('d: ' + JSON.stringify(data)); }
    );