连接HiveMQ代理器实现MQTT协议传输

先下载MQTTX: MQTTX: Your All-in-one MQTT Client Toolbox

使用线上免费的MQTTX BROKER:The Free Global Public MQTT Broker | Try Now | EMQ

打开MQTTX,创建连接,点击NEW SUBSCRIPTION,创建一个主题,这里使用test/topic,在下面Json中填写配置好的主题,点击发送测试OK。订阅者,建立一个主题:

java 复制代码
package com.jasonhong.application.media.mq.mqtt;

import org.eclipse.paho.client.mqttv3.IMqttDeliveryToken;
import org.eclipse.paho.client.mqttv3.MqttCallback;  
import org.eclipse.paho.client.mqttv3.MqttClient;  
import org.eclipse.paho.client.mqttv3.MqttConnectOptions;  
import org.eclipse.paho.client.mqttv3.MqttException;  
import org.eclipse.paho.client.mqttv3.MqttMessage;  
import org.eclipse.paho.client.mqttv3.persist.MemoryPersistence;  
  
public class MqttSubscriber implements MqttCallback {  
  
    public static void main(String[] args) {  
        String brokerUrl = "tcp://broker.hivemq.com:1883"; // 使用公共MQTT代理或你的MQTT代理地址
//        String brokerUrl = "tcp://localhost:1883"; // Mosquitto代理地址和端口
        String clientId = "JavaSubscriber";  
        String topic = "test/topic";  
        int qos = 2;  
  
        try (MqttClient client = new MqttClient(brokerUrl, clientId, new MemoryPersistence())) {  
            client.setCallback(new MqttSubscriber());  
            MqttConnectOptions connOpts = new MqttConnectOptions();  
            connOpts.setCleanSession(true);  
            client.connect(connOpts);  
            client.subscribe(topic, qos);  
        } catch (MqttException e) {  
            e.printStackTrace();  
        }  
    }  
  
    @Override  
    public void connectionLost(Throwable cause) {  
        System.out.println("Connection lost");  
        cause.printStackTrace();  
    }  
  
    @Override  
    public void messageArrived(String topic, MqttMessage message) throws Exception {  
        System.out.println("Message arrived: " + new String(message.getPayload()));  
    }  
  
    @Override  
    public void deliveryComplete(IMqttDeliveryToken token) {  
        System.out.println("Delivery complete");  
    }  
}

发布者发送给一个消息

java 复制代码
package com.jasonhong.application.media.mq.mqtt;

import org.eclipse.paho.client.mqttv3.MqttClient;
import org.eclipse.paho.client.mqttv3.MqttConnectOptions;  
import org.eclipse.paho.client.mqttv3.MqttException;  
import org.eclipse.paho.client.mqttv3.MqttMessage;  
import org.eclipse.paho.client.mqttv3.persist.MemoryPersistence;  
  
public class MqttPublisher {  
  
    public static void main(String[] args) {  
        String brokerUrl = "tcp://broker.hivemq.com:1883"; // 使用公共MQTT代理或你的MQTT代理地址
//        String brokerUrl = "tcp://localhost:1883"; // Mosquitto代理地址和端口
        String clientId = "JavaPublisher";  
        String topic = "test/topic";  
        int qos = 2;  
        String content = "Hello, MQTT!";  
  
        try (MqttClient client = new MqttClient(brokerUrl, clientId, new MemoryPersistence())) {  
            MqttConnectOptions connOpts = new MqttConnectOptions();  
            connOpts.setCleanSession(true);  
            client.connect(connOpts);  
            MqttMessage message = new MqttMessage(content.getBytes());  
            message.setQos(qos);  
            client.publish(topic, message);  
            System.out.println("Message published: " + content);  
        } catch (MqttException e) {  
            e.printStackTrace();  
        }  
    }  
}
相关推荐
会Tk矩阵群控的小木4 分钟前
基于Python的iMessage短信群发与社媒多账号统一管理系统实现
开发语言·windows·python·新媒体运营·开源软件·个人开发
程序员黑豆7 分钟前
AI全栈开发 - Java:变量
java·前端·ai编程
我是一颗柠檬7 分钟前
【Java项目技术亮点】分库分表+数据路由策略:单表5000万后的架构升级方案
java·开发语言·分布式·架构
wu_ye_m9 分钟前
学习c语言第35天 函数声明和定义
c语言·开发语言·学习
布朗克16816 分钟前
25 IO流高级操作——序列化、NIO与Files工具类
java·数据库·io·nio
njsgcs17 分钟前
c# solidworks 创建装配体工程图+bom
开发语言·c#·solidworks
小研说技术20 分钟前
Spring AI实现rag流程(简易版)
java·后端
亓才孓26 分钟前
【本地项目引用外部库的类,想修改字段遇到的请缓存的问题】
java·maven
小林敲代码778836 分钟前
记录一下IDEA中很多变量变色的方案
java·开发语言·spring boot·idea
南知意-40 分钟前
IDEA 2026.1最新版安装教程
java·ide·intellij-idea·idea安装·idea激活