mqtt基于paho的消息订阅接收的JAVA代码

2024-02-12 20:18

本文主要是介绍mqtt基于paho的消息订阅接收的JAVA代码,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

看到网上的部分代码,对于订阅主题后,使用mqttCallBack接口来接收消息,虽然这种方法也可以接收到消息,但是mqtt Paho提供了正规的方法去接收消息,这里分享一下自己的demo。

使用callback接口订阅类:


import org.eclipse.paho.client.mqttv3.IMqttDeliveryToken;
import org.eclipse.paho.client.mqttv3.IMqttToken;
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;import edu.jia.pub.Publish;public class Subscribe {public static final String HOST = "tcp://116.196.99.111:1883";public static final String TOPIC = "topic";private static final String clientid = "Client Subscribe";private MqttClient client;private MqttConnectOptions options;private String msg = null;// private String userName = "admin";// private String passWord = "password";// private ScheduledExecutorService scheduler;public MqttClient connect() throws MqttException {// host为主机名,clientid即连接MQTT的客户端ID,一般以唯一标识符表示,MemoryPersistence设置clientid的保存形式,默认为以内存保存this.client = new MqttClient(HOST, clientid, new MemoryPersistence());// MQTT的连接设置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);// 设置回调this.client.setCallback(new MqttCallback() {public void connectionLost(Throwable cause) {// 连接丢失后,一般在这里面进行重连System.out.println("连接断开,可以做重连");}public void deliveryComplete(IMqttDeliveryToken token) {System.out.println("deliveryComplete---------" + token.isComplete());}public void messageArrived(String topic, MqttMessage message) throws Exception {// subscribe后得到的消息会执行到这里面System.out.println("接收消息的主题 : " + topic);System.out.println("接收消息的质量Qos : " + message.getQos());//msg = new String(message.getPayload());System.out.println(">>>>>>>>>>>>>>>>>>>" + msg);}});// MqttTopic topic = client.getTopic(TOPIC);// setWill方法,如果项目中需要知道客户端是否掉线可以调用该方法。设置最终端口的通知消息// options.setWill(topic, "close".getBytes(), 2, true);this.client.connect(options);return this.client;}public IMqttToken subscribe(MqttClient client) throws MqttException {// 订阅消息int Qos = 2;String topic1 = TOPIC;IMqttToken token = client.subscribeWithResponse(topic1, Qos);String str = new String(token.getResponse().getPayload());System.out.println("============================" + str);return token;}public static void main(String[] args) throws Throwable {System.out.println("下发配置");Thread.sleep(3000);System.out.println("配置已经下发");Thread.sleep(3000);System.out.println("监听回传消息");Subscribe sub = new Subscribe();MqttClient client = sub.connect();Thread.sleep(3000);System.out.println("建立连接");IMqttToken token = sub.subscribe(client);if (token.isComplete()) {System.out.println("完成订阅");Publish Publish = new Publish();Publish.setMessage(new MqttMessage());Publish.getMessage().setQos(2);Publish.getMessage().setRetained(true);Publish.getMessage().setPayload("2018/06-------mqtt服务端测试   msg2".getBytes());// 重写publish方法Publish.publish(Publish.getTopic(), Publish.getMessage());Publish.getClient().disconnect();}if (sub.msg == null) {Thread.sleep(3000);if (sub.msg!=null) {System.out.println("====================" + sub.msg);}else {System.out.println("time out ");}}}}

使用subscribe方法接收消息:

package edu.jia.sub;
import org.eclipse.paho.client.mqttv3.IMqttMessageListener;
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 TestSub {private static int qos = 2;private static String broker = "tcp://116.196.99.111:1883";private static MqttClient connect(String clientId) throws MqttException{MemoryPersistence persistence = new MemoryPersistence();MqttConnectOptions connOpts = new MqttConnectOptions();connOpts.setCleanSession(false);connOpts.setConnectionTimeout(10);connOpts.setKeepAliveInterval(20);MqttClient mqttClient = new MqttClient(broker, clientId, persistence);mqttClient.connect(connOpts);return mqttClient;}public static void sub(MqttClient mqttClient,String topic) throws MqttException{int[] Qos  = {qos};String[] topics = {topic};mqttClient.subscribe(topics, Qos);}private static void runsub(String clientId, String topic) throws MqttException{MqttClient mqttClient = connect(clientId);if(mqttClient != null){sub(mqttClient,topic);}mqttClient.subscribe(topic,2, new IMqttMessageListener() {@Overridepublic void messageArrived(String topic, MqttMessage message) throws Exception {// TODO Auto-generated method stubSystem.out.println(new String(message.getPayload()));}});}public static void main(String[] args) throws MqttException{runsub("testSub", "test");}
}

测试:在远程主机,开启mqtt服务:mosquitto -c /etc/mosquitto/mosquitto.conf

mostuitto_pub -p 1883 -q 2 -t "test " -m "test ---- ok " 

多说几句:subscribe提供了三个重载方法,大家可以根据自己的需要选择需要的重载函数,如果对于listener要求比较高的话,可以将内部类单独写出来继承接口即可。

这篇关于mqtt基于paho的消息订阅接收的JAVA代码的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/703503

相关文章

Spring事务传播机制最佳实践

《Spring事务传播机制最佳实践》Spring的事务传播机制为我们提供了优雅的解决方案,本文将带您深入理解这一机制,掌握不同场景下的最佳实践,感兴趣的朋友一起看看吧... 目录1. 什么是事务传播行为2. Spring支持的七种事务传播行为2.1 REQUIRED(默认)2.2 SUPPORTS2

怎样通过分析GC日志来定位Java进程的内存问题

《怎样通过分析GC日志来定位Java进程的内存问题》:本文主要介绍怎样通过分析GC日志来定位Java进程的内存问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、GC 日志基础配置1. 启用详细 GC 日志2. 不同收集器的日志格式二、关键指标与分析维度1.

Java进程异常故障定位及排查过程

《Java进程异常故障定位及排查过程》:本文主要介绍Java进程异常故障定位及排查过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、故障发现与初步判断1. 监控系统告警2. 日志初步分析二、核心排查工具与步骤1. 进程状态检查2. CPU 飙升问题3. 内存

java中新生代和老生代的关系说明

《java中新生代和老生代的关系说明》:本文主要介绍java中新生代和老生代的关系说明,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、内存区域划分新生代老年代二、对象生命周期与晋升流程三、新生代与老年代的协作机制1. 跨代引用处理2. 动态年龄判定3. 空间分

Java设计模式---迭代器模式(Iterator)解读

《Java设计模式---迭代器模式(Iterator)解读》:本文主要介绍Java设计模式---迭代器模式(Iterator),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,... 目录1、迭代器(Iterator)1.1、结构1.2、常用方法1.3、本质1、解耦集合与遍历逻辑2、统一

Java内存分配与JVM参数详解(推荐)

《Java内存分配与JVM参数详解(推荐)》本文详解JVM内存结构与参数调整,涵盖堆分代、元空间、GC选择及优化策略,帮助开发者提升性能、避免内存泄漏,本文给大家介绍Java内存分配与JVM参数详解,... 目录引言JVM内存结构JVM参数概述堆内存分配年轻代与老年代调整堆内存大小调整年轻代与老年代比例元空

深度解析Java DTO(最新推荐)

《深度解析JavaDTO(最新推荐)》DTO(DataTransferObject)是一种用于在不同层(如Controller层、Service层)之间传输数据的对象设计模式,其核心目的是封装数据,... 目录一、什么是DTO?DTO的核心特点:二、为什么需要DTO?(对比Entity)三、实际应用场景解析

Java 线程安全与 volatile与单例模式问题及解决方案

《Java线程安全与volatile与单例模式问题及解决方案》文章主要讲解线程安全问题的五个成因(调度随机、变量修改、非原子操作、内存可见性、指令重排序)及解决方案,强调使用volatile关键字... 目录什么是线程安全线程安全问题的产生与解决方案线程的调度是随机的多个线程对同一个变量进行修改线程的修改操

从原理到实战深入理解Java 断言assert

《从原理到实战深入理解Java断言assert》本文深入解析Java断言机制,涵盖语法、工作原理、启用方式及与异常的区别,推荐用于开发阶段的条件检查与状态验证,并强调生产环境应使用参数验证工具类替代... 目录深入理解 Java 断言(assert):从原理到实战引言:为什么需要断言?一、断言基础1.1 语

深度解析Java项目中包和包之间的联系

《深度解析Java项目中包和包之间的联系》文章浏览阅读850次,点赞13次,收藏8次。本文详细介绍了Java分层架构中的几个关键包:DTO、Controller、Service和Mapper。_jav... 目录前言一、各大包1.DTO1.1、DTO的核心用途1.2. DTO与实体类(Entity)的区别1