【问题标题】:appengine channel no messages arriveappengine 频道没有消息到达
【发布时间】:2011-09-29 04:39:19
【问题描述】:

我正在尝试让频道 api 正常工作。 这是我目前所拥有的:

在视图中:

def channel_test(channel_token):
    tries = 1
    logging.info('starting channel_test')
    for attempt in range(tries):
        message = 'this is message number: ' + str(attempt)
        channel.send_message(channel_token, message)
        logging.info('just sent: ' + message)
        logging.info(channel_token)

def viewfunc():
    channel_token = channel.create_channel('aosasdf123')
    deferred.defer(channel_test, channel_token, _countdown=10)
    return render_template('Main/cycle.html', form=form, channel_token=channel_token)

在我的模板中:

<script type="text/javascript" charset="utf-8">
    function tell_user(message) {
        $('#CycleChannelMessages').append(message + '<br />');
    }

    function onOpened() {
        console.log('onOpened');
        var connected = true;
        tell_user('ready to take messages');
        tell_user('{{ channel_token }}');
    }
    function onMessage(msg_obj) {
        console.log('onMessage');
        tell_user('something');
        // tell_user(msg_obj.data);

    }
    function onError(obj) {
        console.log('onError');
    }
    function onClose(obj) {
        console.log('onClose');
    }

    var channel = new goog.appengine.Channel('{{ channel_token }}');
    var socket = channel.open();
    socket.onopen = onOpened;
    socket.onmessage = onMessage;
    socket.onerror = onError;
    socket.onclose = onClose;
</script>

但我得到的唯一输出来自 onOpen:

ready to take messages
channel-1788270053-aosasdf123

而在控制台中我只看到:

onOpened

所以没有运行其他函数。来自 appengine 启动器的日志清楚地显示延迟函数正在运行,并且没有导致错误或警告。

现在我做错了什么,因为前端没有显示任何内容。 这是在开发服务器 BTW 上。我还没有在生产中尝试过。

如果这有什么不同的话,框架就是 Flask。

【问题讨论】:

    标签: javascript python google-app-engine flask channel


    【解决方案1】:

    您将client_id 传递给send_message 而不是channel_token。所以你的代码应该是:

    channel.send_message('aosasdf123', message)
    

    您将 channel_token 放置在客户端以打开通道,并将 client_id 保密在服务器端以通过通道将消息传输到该客户端。

    【讨论】:

    • 非常感谢。我确定这是我错过的一些愚蠢的事情
    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2012-04-16
    • 2017-02-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2022-06-13
    相关资源
    最近更新 更多