【问题标题】:send downstream message to google ccs with node js使用节点 js 向 google ccs 发送下游消息
【发布时间】:2014-05-01 15:07:54
【问题描述】:

我正在使用node-xmpp 连接到 google gcm ccs 服务器。我跟着from gcm google groups 连接。现在,每当我收到来自我的 redis 订阅者的消息(我订阅了一个 redis 频道redis node package)时,我都需要发送一条下游消息。我的代码如下

var gearmanode = require('gearmanode');
var redis = require("redis");
var xmpp = require('node-xmpp');

var gearJob;
var redisSubChan = 'test_channel';
var gearmanJobName = 'reverse';
var jobPayload;
var redisClient;
var xmppClient;
var gearClient;

gearClient = gearmanode.client();

var options = {
    type: 'client',
    jid: 'myid@gcm.googleapis.com',
    password: 'myserverkey',
    port: 5235,
    host: 'gcm.googleapis.com',
    legacySSL: true,
    preferredSaslMechanism: 'PLAIN'
};

console.log('creating xmpp app');

xmppClient = new xmpp.Client(options);

xmppClient.connection.socket.setTimeout(0)
xmppClient.connection.socket.setKeepAlive(true, 10000)

redisClient = redis.createClient();
redisClient.subscribe(redisSubChan);

redisClient.on("message", function(channel, message) {
    console.log('received message');
    console.log(message);
    message = JSON.parse(message);
    //send the messages to google ccs server via xmpp
    var payload = {
        "to": message.to,
        "message_id": message.message_id,
        "data": message.data,
        "time_to_live": message.time_to_live,
        "delay_while_idle": message.delay_while_idle
    };
    var jsonPayload = JSON.stringify(payload);
    console.log(jsonPayload);

    var ackToDevice = new xmpp.Element('message', {'id': ''}).c('gcm', {xmlns: 'google:mobile:data'}).t(jsonPayload);
    console.log('prepared message');
    console.log(ackToDevice.root().toString());
    xmppClient.send(ackToDevice);
    console.log('sent!!!');
});

xmppClient.on('online', function() {
    console.log("online");
});

xmppClient.on('connection', function() {
    console.log('online');
});

xmppClient.on('stanza',
        function(stanza) {
            if (stanza.is('message') && stanza.attrs.type !== 'error') {
                // Best to ignore an error
                console.log("Message received");
                //Message format as per here: https://developer.android.com/google/gcm/ccs.html#upstream
                var messageData = JSON.parse(stanza.getChildText("gcm"));

                if (messageData && messageData.message_type != "ack" && messageData.message_type != "nack") {

                    var ackMsg = new xmpp.Element('message', {'id': ''}).c('gcm', {xmlns: 'google:mobile:data'}).t(JSON.stringify({
                        "to": messageData.from,
                        "message_id": messageData.message_id,
                        "message_type": "ack"
                    }));
                    //send back the ack.
                    xmppClient.send(ackMsg);
                    console.log("Sent ack");
                    //receive messages from ccs and give it to PHP workers
                    gearClient.submitJob(gearmanJobName, JSON.stringify(messageData), {background: true});

                } else {
                    //Need to do something more here for a nack.
                    console.log("message was an ack or nack...discarding");
                }

            } else {
                console.log("error");
                console.log(stanza);
            }

        });

xmppClient.on('authenticate', function(opts, cb) {
    console.log('AUTH' + opts.jid + ' -> ' + opts.password);
    cb(null);
});

xmppClient.on('error', function(e) {
    console.log("Error occured:");
    console.error(e);
    console.error(e.children);
});

我能够接收来自 ccs 服务器的消息,但 不能 在消息回调时从 redis 发送下游消息。

我收到以下错误

error
{ name: 'message',
  parent: null,
  attrs: 
   { id: '',
     type: 'error',
     to: '1026645507924@gcm.googleapis.com/8DF23ED7',
     'xmlns:stream': 'http://etherx.jabber.org/streams' },
  children: 
   [ { name: 'gcm',
       parent: [Circular],
       attrs: [Object],
       children: [Object] },
     { name: 'error',
       parent: [Circular],
       attrs: [Object],
       children: [Object] } ] }

我尝试在发送之前打印(跟随node xmpp)xmpp 节,它的相同

//我的消息记录

<message id=""><gcm xmlns="google:mobile:data">{"to":"APA91bHIGZcbePZ-f1jSyWQkBAJMHorHJiwgtN1GWITzcHf6uyVOZ3k7AasUiB-vBix32ucSypin3xDTYmoxqSc_ZmTDTuKjuDQ8BPQLpC41SqYRimm-hn34ZjSAF4uQO0OP1LSbqUxjh2WF0K5n4KyD3-Vn8ghASQ","message_id":84,"data":{"test":"sample data to send"},"time_to_live":0,"delay_while_idle":false}</gcm></message>

正如他们在文档中提到的 (Request format)。我的代码有什么问题?

【问题讨论】:

  • 请显示完整的错误消息,[Object] 和 [Circular] 实体背后是什么?
  • 现在它可以使用相同的代码。不知道为什么?

标签: android node.js redis xmpp google-cloud-messaging


【解决方案1】:

我有同样的问题。它几乎让我发疯,但最终它只是一个无效的 JSON 格式错误。

我想 messageData.from 或 messageData.message_id 未转换为正确的 JSON 格式。就我而言,我传递了一个标量,而 JSON.stringify() 没有将其转换为字符串。因此结果是 --> "message_id": 1234 而不是 "message_id": "1234"

【讨论】:

    【解决方案2】:

    快速回答是,如果您的项目未列入白名单,您将无法使用 CCS (XMPP)。如果您尝试改用 smack 库,则会收到一条错误消息,指出您的项目未列入白名单。

    【讨论】:

    • 我的项目被列入白名单,ccs 也发送上游消息。
    猜你喜欢
    • 2015-07-30
    • 2021-10-23
    • 2016-09-29
    • 2016-11-25
    • 2021-01-10
    • 2010-10-25
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多