nodejs - 为什么mosca服务器发布一个刚刚发布的消息客户端

时间:2017-09-27 12:39:02

标签: node.js mqtt mosca

我正在制作一个物联网项目,使用mosca服务器,mqtt.js和express和jQuery来制作网页。我的目的是建立一个可以与一些嵌入式电路板通信的网站,例如Arduino,esp,......

当我向服务器发布一些消息时,我希望服务器发布回“Hello World”。但问题是,当我这样做时,服务器发送回“Hello World”和我刚刚发布的消息。

以下是示例代码:

服务器mosca

var mosca = require("mosca");

var settings = {
    http: {
        port: 8080,
        bundle: true,
        static: './'
    }
};

var server = new mosca.Server(settings);

server.on('clientConnected', function(client) {
    console.log('client ' +  client.id+ ' connect');
});

server.on('clientDisconnected', function(client) {
    console.log('client ' +  client.id+ ' disconnect');
});

// fired when a packet is send from server and is received from client
server.on('published', function(packet, client) {
    // console.log('Published', packet);
    if(typeof packet.payload == "object"){
            console.log(packet);
            console.log("From Client(Buffer) : "+ packet.payload.toString());
            var mesFromServer = {
                        topic:packet.topic,
                        payload:"Hello World",
                        qos:0,
                        retain:false
                    };
            server.publish(mesFromServer,client);
    }
});

server.on('ready', setup);

// fired when the mqtt server is ready
function setup() {
    console.log('Mosca server is up and running');
}

client.js使用mqtt.js

$(document).ready(function(){
    $("#btnConnect").click(function(){

        $("#Connect-loader").css("display","inline");
        var client  = mqtt.connect({ host: 'localhost', port:8080 });
    
        client.on('connect', function () {
            if(client.connected)
            {
                $("#Connect-loader").css("display","none");
                $("#btnConnect").prop("disabled",true);
                $("#btnDisconnect").prop("disabled",false);
                $("#connect-notification").html("Server connected");
                $("#connect-notification").css("color","green");
            }
        });
        
        client.on('message', function (topic, message,packet) {
            // message is Buffer
            console.log(packet);
            $("#txtDataFromServer").val($("#txtDataFromServer").val()+"From Server: " + message.toString()+"\n");
        });

        client.on('close',function(){
            $("#btnConnect").prop("disabled",false);
            $("#btnDisconnect").prop("disabled",true);

            $("#connect-notification").html("Server disconnected");
            $("#connect-notification").css("color","red");
        });

        $("#btnSend").click(function(){
            var topic = $("#txtTopic").val();
            var mess = $("#txtMessage").val();
            
            if(topic != "" && mess !=""){
                client.subscribe(topic);
                client.publish(topic,mess,{qos:0,retain:false});
            }
        });
        
        $("#btnDisconnect").click(function(){
           client.end(); 
        });
    });
});

index.js使用快递

var express = require("express");
var app = express();

app.use(express.static("public")); 
app.use(express.static("node_modules"));

app.set("view engine","ejs");
app.set("views","./views");
var server = require("http").createServer(app);

server.listen(8000);

app.get("/",function(req,res){
    res.render("home");
});

我启动服务器mosca和index.js:

  

node server.js

     

node index.js

然后我在网上点击了一个按钮连接到mosca,然后向它发送了一条消息'hello mqtt + mosca',但它向我发回了2条消息。

  

来自服务器:hello mqtt + mosca

     

来自服务器:Hello World

我不希望结果'你好mqtt + mosca'。如何阻止服务器向我发布我发布给它的消息?

2 个答案:

答案 0 :(得分:0)

简短的回答是你没有。

如果客户订阅某个主题,它将收到在该主题上发布的所有消息,无论是谁发布它。

这就是MQTT的工作原理。

答案 1 :(得分:0)

连接到服务器时有用户数据选项设置,为每个客户端添加一些唯一的数据,您将在消息事件处理程序中获取这些数据,根据这些数据设置条件。