EMQ Java客户端 发送消息/接收消息 的使用

1 添加maven依赖

<dependency>
      <groupId>org.eclipse.paho</groupId>
      <artifactId>org.eclipse.paho.client.mqttv3</artifactId>
      <version>1.2.2</version>
</dependency>

常见类功能说明

基类介绍
MqttClient同步调用客户端,使用阻塞方法与MQTT服务器通信。
MqttAsyncClient异步调用客户端,使用非阻塞方法与MQTT服务器通信,允许操作在后台运行。
MqttClientPersistence表示持久性数据存储,用于存储正在传输的出站和入站消息,从而实现向指定的QoS的传递。 可以使用 MqttClient指定此接口的实现,MqttClient将使用该实现来持久保存QoS为1和2消息。
MqttConnectOptions保存控制客户端连接到服务器的方式的选项集,包括用户名、密码等。
MqttMessageMQTT消息,保存应用程序有效负载和指定消息如何传递的选项消息。

下面包含的代码是一个非常基本的示例,它连接到服务器并使用MqttClient同步API发布/订阅消息。

生产者代码

package cn.huawei.client;

import org.eclipse.paho.client.mqttv3.*;
import org.eclipse.paho.client.mqttv3.persist.MemoryPersistence;

/**
 *发布端发送消息
 * 1 创建 MqttClient(broker,clientId)
 * 2 MqttClient.setCallback(new MqttCallback() {}) 设置回调函数
 * 3 MqttClient.connect(用户名,密码)
 * 4 MqttClient.publish() 往主题发送消息
 * 5 MqttClient.disconnect() 断开连接
 * 6 MqttClient.close() 关闭
 */
public class PublishSample {
    public static void main(String[] args) {

        String topic = "mqtt/test";
        int qos = 1;
        String broker = "tcp://127.0.0.1:1883";
        String userName = "username_1";
        String password = "123456";
        String clientId = "pubClient";

        // 内存存储
        MemoryPersistence persistence = new MemoryPersistence();

        try {
            // 创建客户端
            MqttClient sampleClient = new MqttClient(broker, clientId, persistence);

            // 创建链接参数
            MqttConnectOptions connOpts = new MqttConnectOptions();
            // 在重新启动和重新连接时记住状态
            connOpts.setCleanSession(false);
            // 自动重连
            connOpts.setAutomaticReconnect(true);
            // 设置连接的用户名
            connOpts.setUserName(userName);
            connOpts.setPassword(password.toCharArray());

            // 设置回调函数
            sampleClient.setCallback(new MqttCallback() {

                public void connectionLost(Throwable cause) {
                    // 连接丢失后,一般在这里面进行重连
                    System.out.println("连接断开,可以做重连");
                }

                public void messageArrived(String topic, MqttMessage message) throws Exception {
                }

                public void deliveryComplete(IMqttDeliveryToken token) {
                    /**
                     * 消息发布完成且收到ack确认后的回调
                     * QoS0:消息被网络发出后触发一次
                     * QoS1:当收到broker的PUBACK消息后触发
                     * QoS2:当收到broer的PUBCOMP消息后触发
                     */
                    System.out.println("deliveryComplete---------"+ token.isComplete());
                }

            });


            // 建立连接
            sampleClient.connect(connOpts);


            for (int i = 0; i < 11; i++)
            {
                // 创建消息
                MqttMessage message = new MqttMessage(("hello 哈哈---"+i).getBytes());
                // 设置消息的服务质量
                message.setQos(qos);
                // 发布消息
                sampleClient.publish(topic, message);
            }
            // 断开连接
            sampleClient.disconnect();
            // 关闭客户端
            sampleClient.close();
        } catch (MqttException me) {
            System.out.println("reason " + me.getReasonCode());
            System.out.println("msg " + me.getMessage());
            System.out.println("loc " + me.getLocalizedMessage());
            System.out.println("cause " + me.getCause());
            System.out.println("excep " + me);
            me.printStackTrace();
        }
    }
}

消费者代码

package cn.huawei.client;

import org.eclipse.paho.client.mqttv3.*;
import org.eclipse.paho.client.mqttv3.persist.MemoryPersistence;

/**
 *订阅端 接收消息
 * 1 创建 MqttClient(broker,clientId)
 * 2 MqttClient.setCallback(new MqttCallback() {}) 设置回调函数
 * 3 MqttClient.connect(用户名,密码)
 * 4 MqttClient.subscribe() 订阅主题消息
 */
public class SubscribeSample {
    public static void main(String[] args) throws MqttException {

        String HOST = "tcp://127.0.0.1:1883";
        String TOPIC = "mqtt/test";
        int qos = 1;
        String clientid = "subClient";
        String userName = "username_1";
        String passWord = "123456";
        try {
            // host为主机名,test为clientid即连接MQTT的客户端ID,一般以客户端唯一标识符表示,MemoryPersistence设置clientid的保存形式,默认为以内存保存
            MqttClient client = new MqttClient(HOST, clientid, new MemoryPersistence());

            // MQTT的连接设置
            MqttConnectOptions options = new MqttConnectOptions();
            // 设置是否清空session,这里如果设置为false表示服务器会保留客户端的连接记录,这里设置为true表示每次连接到服务器都以新的身份连接
            options.setCleanSession(true);
            // 设置连接的用户名
            options.setUserName(userName);
            // 设置连接的密码
            options.setPassword(passWord.toCharArray());
            // 设置超时时间 单位为秒
            options.setConnectionTimeout(10);
            // 设置会话心跳时间 单位为秒 服务器会每隔1.5*20秒的时间向客户端发送个消息判断客户端是否在线,但这个方法并没有重连的机制
            options.setKeepAliveInterval(20);
            // 自动重连
            options.setAutomaticReconnect(true);

            // 设置回调函数
            client.setCallback(new MqttCallback() {

                public void connectionLost(Throwable cause) {
                    // 连接丢失后,一般在这里面进行重连
                    System.out.println("连接断开,可以做重连");
                }

                public void messageArrived(String topic, MqttMessage message) throws Exception {
                    /**
                     * 订阅到消息后的回调
                     * 该方法由mqtt客户端同步调用,在此方法未正确返回之前,不会发送ack确认消息到broker
                     * 一旦该方法向外抛出了异常客户端将异常关闭,当再次连接时;所有QoSl,QoS2且客户端未进行ack确认的消息都将由
                     * broker服务器再次发送到客户端
                     */
                    System.out.println("messageId:" +message.getId());
                    System.out.println("接收消息主题:" + topic);
                    System.out.println("接收消息Qos:" + message.getQos());
                    System.out.println("接收消息内容:" + new String(message.getPayload()));
                    System.out.println();
                }

                public void deliveryComplete(IMqttDeliveryToken token) {
                    /**
                     * 消息发布完成且收到ack确认后的回调
                     * QoS0:消息被网络发出后触发一次
                     * QoS1:当收到broker的PUBACK消息后触发
                     * QoS2:当收到broer的PUBCOMP消息后触发
                     */
                    System.out.println("deliveryComplete---------"+ token.isComplete());
                }

            });

            // 建立连接
            client.connect(options);

            //订阅消息
            client.subscribe(TOPIC, qos);
        } catch (Exception e) {
            e.printStackTrace();
        }
    }
}

参考博文
https://blog.csdn.net/u012851114/article/details/103346132

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值