天天看點

MQTT協定之訂閱及釋出(使用paho-mqtt-client或mqttv3實作)

另外一個MQTT釋出訂閱用戶端paho-mqtt-client或mqttv3采用回調的方式實作消息的接收,下面看一下實作:

1.消息接收回調類

[java] 

view plain

 copy

 print

?

  1. package cn.smartslim.mqtt.demo.paho;  
  2. import org.eclipse.paho.client.mqttv3.MqttCallback;  
  3. import org.eclipse.paho.client.mqttv3.MqttDeliveryToken;  
  4. import org.eclipse.paho.client.mqttv3.MqttMessage;  
  5. import org.eclipse.paho.client.mqttv3.MqttTopic;  
  6. /**  
  7.  * 釋出消息的回調類  
  8.  *   
  9.  * 必須實作MqttCallback的接口并實作對應的相關接口方法  
  10.  *      ◦CallBack 類将實作 MqttCallBack。每個客戶機辨別都需要一個回調執行個體。在此示例中,構造函數傳遞客戶機辨別以另存為執行個體資料。在回調中,将它用來辨別已經啟動了該回調的哪個執行個體。  
  11.  *  ◦必須在回調類中實作三個方法:  
  12.  *  public void messageArrived(MqttTopic topic, MqttMessage message)  
  13.  *  接收已經預訂的釋出。  
  14.  *  public void connectionLost(Throwable cause)  
  15.  *  在斷開連接配接時調用。  
  16.  *  public void deliveryComplete(MqttDeliveryToken token))  
  17.  *      接收到已經釋出的 QoS 1 或 QoS 2 消息的傳遞令牌時調用。  
  18.  *  ◦由 MqttClient.connect 激活此回調。  
  19.  */    
  20. public class PushCallback implements MqttCallback {  
  21.     public void connectionLost(Throwable cause) {  
  22.         // 連接配接丢失後,一般在這裡面進行重連  
  23.         System.out.println("連接配接斷開,可以做重連");  
  24.     }  
  25.     public void deliveryComplete(MqttDeliveryToken token) {  
  26.         // publish後會執行到這裡  
  27.         System.out.println("deliveryComplete---------"+ token.isComplete());  
  28.     public void messageArrived(MqttTopic topic, MqttMessage message) throws Exception {  
  29.         // subscribe後得到的消息會執行到這裡面  
  30.         System.out.println("接收消息主題:"+topic.getName());  
  31.         System.out.println("接收消息Qos:"+message.getQos());  
  32.         System.out.println("接收消息内容:"+new String(message.getPayload()));  
  33. }  

2.服務端釋出消息

  1. import org.eclipse.paho.client.mqttv3.MqttClient;  
  2. import org.eclipse.paho.client.mqttv3.MqttConnectOptions;  
  3. import org.eclipse.paho.client.mqttv3.MqttException;  
  4. import org.eclipse.paho.client.mqttv3.MqttPersistenceException;  
  5. import org.eclipse.paho.client.mqttv3.internal.MemoryPersistence;  
  6. public class Server {  
  7.     public static final String HOST = "tcp://192.168.36.102:1883";  
  8.     public static final String TOPIC = "tokudu/yzq124";  
  9.     private static final String clientid ="server";   
  10.     private MqttClient client;  
  11.     private MqttTopic topic;  
  12.     private String userName = "test";  
  13.     private String passWord = "test";  
  14.     private MqttMessage message;  
  15.     public Server() throws MqttException {  
  16.          //MemoryPersistence設定clientid的儲存形式,預設為以記憶體儲存  
  17.         client = new MqttClient(HOST, clientid, new MemoryPersistence());  
  18.         connect();  
  19.     private void connect() {  
  20.         MqttConnectOptions options = new MqttConnectOptions();  
  21.         options.setCleanSession(false);  
  22.         options.setUserName(userName);  
  23.         options.setPassword(passWord.toCharArray());  
  24.         // 設定逾時時間  
  25.         options.setConnectionTimeout(10);  
  26.         // 設定會話心跳時間  
  27.         options.setKeepAliveInterval(20);  
  28.         try {  
  29.                client.setCallback(new PushCallback());  
  30.                client.connect(options);  
  31.                topic = client.getTopic(TOPIC);  
  32.         } catch (Exception e) {  
  33.                e.printStackTrace();  
  34.         }  
  35.     public void publish(MqttMessage message) throws MqttPersistenceException, MqttException{  
  36.         MqttDeliveryToken token = topic.publish(message);  
  37.         token.waitForCompletion();  
  38.         System.out.println(token.isComplete()+"========");  
  39.     public static void main(String[] args) throws MqttException {  
  40.         Server server =  new Server();  
  41.         server.message = new MqttMessage();  
  42.         server.message.setQos(1);  
  43.         server.message.setRetained(true);  
  44.         server.message.setPayload("eeeeeaaaaaawwwwww---".getBytes());  
  45.          server.publish(server.message);  
  46.          System.out.println(server.message.isRetained()+"------ratained狀态");  

3.用戶端接收消息

  1. import java.util.concurrent.Executors;  
  2. import java.util.concurrent.ScheduledExecutorService;  
  3. import java.util.concurrent.TimeUnit;  
  4. import org.eclipse.paho.client.mqttv3.MqttSecurityException;  
  5. public class Client {  
  6.     private static final String clientid = "client";  
  7.     private MqttConnectOptions options;  
  8.     private ScheduledExecutorService scheduler;  
  9.     //重新連結  
  10.     public void startReconnect() {  
  11.         scheduler = Executors.newSingleThreadScheduledExecutor();  
  12.         scheduler.scheduleAtFixedRate(new Runnable() {  
  13.             public void run() {  
  14.                 if (!client.isConnected()) {  
  15.                     try {  
  16.                         client.connect(options);  
  17.                     } catch (MqttSecurityException e) {  
  18.                         e.printStackTrace();  
  19.                     } catch (MqttException e) {  
  20.                     }  
  21.                 }  
  22.             }  
  23.         }, 0 * 1000, 10 * 1000, TimeUnit.MILLISECONDS);  
  24.     private void start() {  
  25.             // host為主機名,test為clientid即連接配接MQTT的用戶端ID,一般以用戶端唯一辨別符表示,MemoryPersistence設定clientid的儲存形式,預設為以記憶體儲存  
  26.             client = new MqttClient(HOST, clientid, new MemoryPersistence());  
  27.             // MQTT的連接配接設定  
  28.             options = new MqttConnectOptions();  
  29.             // 設定是否清空session,這裡如果設定為false表示伺服器會保留用戶端的連接配接記錄,這裡設定為true表示每次連接配接到伺服器都以新的身份連接配接  
  30.             options.setCleanSession(true);  
  31.             // 設定連接配接的使用者名  
  32.             options.setUserName(userName);  
  33.             // 設定連接配接的密碼  
  34.             options.setPassword(passWord.toCharArray());  
  35.             // 設定逾時時間 機關為秒  
  36.             options.setConnectionTimeout(10);  
  37.             // 設定會話心跳時間 機關為秒 伺服器會每隔1.5*20秒的時間向用戶端發送個消息判斷用戶端是否線上,但這個方法并沒有重連的機制  
  38.             options.setKeepAliveInterval(20);  
  39.             // 設定回調  
  40.             client.setCallback(new PushCallback());  
  41.             MqttTopic topic = client.getTopic(TOPIC);  
  42.             //setWill方法,如果項目中需要知道用戶端是否掉線可以調用該方法。設定最終端口的通知消息    
  43.             options.setWill(topic, "close".getBytes(), 0, true);  
  44.             client.connect(options);  
  45.             //訂閱消息  
  46.             int[] Qos  = {1};  
  47.             String[] topic1 = {TOPIC};  
  48.             client.subscribe(topic1, Qos);  
  49.             e.printStackTrace();  
  50.     public void disconnect() {  
  51.          try {  
  52.             client.disconnect();  
  53.         } catch (MqttException e) {  
  54.     public static void main(String[] args) throws MqttException {     
  55.         Client client = new Client();  
  56.         client.start();