当前位置:   article > 正文

java 实现mqtt发送和接收消息 客户端代码_com.example.mqtt

com.example.mqtt

mqtt的特点就是可以用很少的网络和硬件资源来保证高并发量的数据传输,其传输的稳定性也可以手动设置Qos(消息质量)。

mqtt服务器多种多样,常见的有ActiveMqtt    EMQ  等,不过无论是什么服务器,其底层机制都是一样的。mqtt客户端可以由java、c语言等多种预言实现,我接下来就以java来示例。

1、mqtt客户端发送消息

mqtt发送消息首先要建立与服务器连接,接下来指定主题topic、消息质量qos、消息体,然后通过发送消息方法将消息发送至服务器,假如其他客户端订阅这个主题就可以接收到这个消息

发送消息客户端:

  1. package com.example.mqtt;
  2. import org.eclipse.paho.client.mqttv3.MqttClient;
  3. import org.eclipse.paho.client.mqttv3.MqttClientPersistence;
  4. import org.eclipse.paho.client.mqttv3.MqttConnectOptions;
  5. import org.eclipse.paho.client.mqttv3.MqttDeliveryToken;
  6. import org.eclipse.paho.client.mqttv3.MqttException;
  7. import org.eclipse.paho.client.mqttv3.MqttMessage;
  8. import org.eclipse.paho.client.mqttv3.MqttPersistenceException;
  9. import org.eclipse.paho.client.mqttv3.MqttTopic;
  10. import org.eclipse.paho.client.mqttv3.persist.MemoryPersistence;
  11. public class MyMqttClient {
  12. public static MqttClient mqttClient = null;
  13. private static MemoryPersistence memoryPersistence = null;
  14. private static MqttConnectOptions mqttConnectOptions = null;
  15. static {
  16. init("123");
  17. }
  18. public static void init(String clientId) {
  19. //初始化连接设置对象
  20. mqttConnectOptions = new MqttConnectOptions();
  21. //初始化MqttClient
  22. if(null != mqttConnectOptions) {
  23. // true可以安全地使用内存持久性作为客户端断开连接时清除的所有状态
  24. mqttConnectOptions.setCleanSession(true);
  25. // 设置连接超时
  26. mqttConnectOptions.setConnectionTimeout(30);
  27. // 设置持久化方式
  28. memoryPersistence = new MemoryPersistence();
  29. if(null != memoryPersistence && null != clientId) {
  30. try {
  31. mqttClient = new MqttClient("tcp://127.0.0.1:1883", clientId,memoryPersistence);
  32. } catch (MqttException e) {
  33. // TODO Auto-generated catch block
  34. e.printStackTrace();
  35. }
  36. }else {
  37. }
  38. }else {
  39. System.out.println("mqttConnectOptions对象为空");
  40. }
  41. System.out.println(mqttClient.isConnected());
  42. //设置连接和回调
  43. if(null != mqttClient) {
  44. if(!mqttClient.isConnected()) {
  45. // 创建回调函数对象
  46. MqttReceriveCallback mqttReceriveCallback = new MqttReceriveCallback();
  47. // 客户端添加回调函数
  48. mqttClient.setCallback(mqttReceriveCallback);
  49. // 创建连接
  50. try {
  51. System.out.println("创建连接");
  52. mqttClient.connect(mqttConnectOptions);
  53. } catch (MqttException e) {
  54. // TODO Auto-generated catch block
  55. e.printStackTrace();
  56. }
  57. }
  58. }else {
  59. System.out.println("mqttClient为空");
  60. }
  61. System.out.println(mqttClient.isConnected());
  62. }
  63. // 关闭连接
  64. public void closeConnect() {
  65. //关闭存储方式
  66. if(null != memoryPersistence) {
  67. try {
  68. memoryPersistence.close();
  69. } catch (MqttPersistenceException e) {
  70. // TODO Auto-generated catch block
  71. e.printStackTrace();
  72. }
  73. }else {
  74. System.out.println("memoryPersistence is null");
  75. }
  76. // 关闭连接
  77. if(null != mqttClient) {
  78. if(mqttClient.isConnected()) {
  79. try {
  80. mqttClient.disconnect();
  81. mqttClient.close();
  82. } catch (MqttException e) {
  83. // TODO Auto-generated catch block
  84. e.printStackTrace();
  85. }
  86. }else {
  87. System.out.println("mqttClient is not connect");
  88. }
  89. }else {
  90. System.out.println("mqttClient is null");
  91. }
  92. }
  93. // 发布消息
  94. public void publishMessage(String pubTopic,String message,int qos) {
  95. if(null != mqttClient&& mqttClient.isConnected()) {
  96. System.out.println("发布消息 "+mqttClient.isConnected());
  97. System.out.println("id:"+mqttClient.getClientId());
  98. MqttMessage mqttMessage = new MqttMessage();
  99. mqttMessage.setQos(qos);
  100. mqttMessage.setPayload(message.getBytes());
  101. MqttTopic topic = mqttClient.getTopic(pubTopic);
  102. if(null != topic) {
  103. try {
  104. MqttDeliveryToken publish = topic.publish(mqttMessage);
  105. if(!publish.isComplete()) {
  106. System.out.println("消息发布成功");
  107. }
  108. } catch (MqttException e) {
  109. // TODO Auto-generated catch block
  110. e.printStackTrace();
  111. }
  112. }
  113. }else {
  114. reConnect();
  115. }
  116. }
  117. // 重新连接
  118. public void reConnect() {
  119. if(null != mqttClient) {
  120. if(!mqttClient.isConnected()) {
  121. if(null != mqttConnectOptions) {
  122. try {
  123. mqttClient.connect(mqttConnectOptions);
  124. } catch (MqttException e) {
  125. // TODO Auto-generated catch block
  126. e.printStackTrace();
  127. }
  128. }else {
  129. System.out.println("mqttConnectOptions is null");
  130. }
  131. }else {
  132. System.out.println("mqttClient is null or connect");
  133. }
  134. }else {
  135. init("123");
  136. }
  137. }
  138. // 订阅主题
  139. public void subTopic(String topic) {
  140. if(null != mqttClient&& mqttClient.isConnected()) {
  141. try {
  142. mqttClient.subscribe(topic, 1);
  143. } catch (MqttException e) {
  144. // TODO Auto-generated catch block
  145. e.printStackTrace();
  146. }
  147. }else {
  148. System.out.println("mqttClient is error");
  149. }
  150. }
  151. // 清空主题
  152. public void cleanTopic(String topic) {
  153. if(null != mqttClient&& !mqttClient.isConnected()) {
  154. try {
  155. mqttClient.unsubscribe(topic);
  156. } catch (MqttException e) {
  157. // TODO Auto-generated catch block
  158. e.printStackTrace();
  159. }
  160. }else {
  161. System.out.println("mqttClient is error");
  162. }
  163. }
  164. }

细心的朋友可能发现我将回调函数注释掉了,其实对于发送消息来讲,注释掉并没有太大影响,有些人可能会说需要在回调函数中编写错误重连代码,但时我觉得不是一个很好的选择,所有已经将重连机制改在发布消息之前,在上面代码中也有体现,不过如果是接收消息客户端则不能注释掉,原因是接收消息要用到回调函数,下面在写一下接收消息的客户端:

2接收消息的客户端:

  1. package com.wanwei.mqtt;
  2. import org.eclipse.paho.client.mqttv3.MqttClient;
  3. import org.eclipse.paho.client.mqttv3.MqttConnectOptions;
  4. import org.eclipse.paho.client.mqttv3.MqttException;
  5. import org.eclipse.paho.client.mqttv3.MqttSecurityException;
  6. import org.eclipse.paho.client.mqttv3.persist.MemoryPersistence;
  7. import com.wanwei.ilogger.ilogger;
  8. public class MyMqttRecieveMessage {
  9. private static int QoS = 1;
  10. private static String Host = "tcp://127.0.0.1:1883";
  11. private static MemoryPersistence memoryPersistence = null;
  12. private static MqttConnectOptions mqttConnectOptions = null;
  13. private static MqttClient mqttClient = null;
  14. public static void init(String clientId) {
  15. mqttConnectOptions = new MqttConnectOptions();
  16. memoryPersistence = new MemoryPersistence();
  17. ilogger ilogger = new ilogger("MyMqttRecieveMessage", "init");
  18. if(null != memoryPersistence && null != clientId && null != Host) {
  19. try {
  20. mqttClient = new MqttClient(Host, clientId, memoryPersistence);
  21. } catch (MqttException e) {
  22. // TODO Auto-generated catch block
  23. e.printStackTrace();
  24. }
  25. }else {
  26. ilogger.logerr("memoryPersistence clientId Host 有空值");
  27. }
  28. if(null != mqttConnectOptions) {
  29. mqttConnectOptions.setCleanSession(true);
  30. mqttConnectOptions.setConnectionTimeout(30);
  31. mqttConnectOptions.setKeepAliveInterval(45);
  32. if(null != mqttClient && !mqttClient.isConnected()) {
  33. mqttClient.setCallback(new MqttRecieveCallback());
  34. try {
  35. mqttClient.connect();
  36. } catch (MqttException e) {
  37. // TODO Auto-generated catch block
  38. e.printStackTrace();
  39. }
  40. }else {
  41. ilogger.logerr("mqttClient is error");
  42. }
  43. }else {
  44. ilogger.logerr("mqttConnectOptions is null");
  45. }
  46. }
  47. public static void recieve(String topic) {
  48. int[] Qos = {QoS};
  49. String[] topics = {topic};
  50. ilogger ilogger = new ilogger("MyMqttRecieveMessage", "subTopic");
  51. if(null != mqttClient && mqttClient.isConnected()) {
  52. if(null!=topics && null!=Qos && topics.length>0 && Qos.length>0) {
  53. try {
  54. mqttClient.subscribe(topics, Qos);
  55. } catch (MqttException e) {
  56. // TODO Auto-generated catch block
  57. e.printStackTrace();
  58. }
  59. }else {
  60. ilogger.logerr("there is error");
  61. }
  62. }else {
  63. init("123444");
  64. recieve(topic);
  65. }
  66. }
  67. }

接收消息客户端回调函数:

  1. package com.wanwei.mqtt;
  2. import org.eclipse.paho.client.mqttv3.IMqttDeliveryToken;
  3. import org.eclipse.paho.client.mqttv3.MqttCallback;
  4. import org.eclipse.paho.client.mqttv3.MqttMessage;
  5. import com.wanwei.bean.ChatMessage;
  6. import com.wanwei.dao.DealMessage;
  7. public class MqttRecieveCallback implements MqttCallback{
  8. @Override
  9. public void connectionLost(Throwable cause) {
  10. }
  11. @Override
  12. public void messageArrived(String topic, MqttMessage message) throws Exception {
  13. System.out.println("Client 接收消息主题 : " + topic);
  14. System.out.println("Client 接收消息Qos : " + message.getQos());
  15. System.out.println("Client 接收消息内容 : " + new String(message.getPayload()));
  16. }
  17. @Override
  18. public void deliveryComplete(IMqttDeliveryToken token) {
  19. }
  20. }

切记接收消息时,以上两个函数缺一不可!!!

下一篇讲一下mqtt客户端具体用法,附带测试方法

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/菜鸟追梦旅行/article/detail/188654
推荐阅读
相关标签
  

闽ICP备14008679号