MQTT服务端连接操作

ESP8266的Arduino开发环境里有多个MQTT库,我们将使用最为流行的PubSubClient库来作为本教程的主要介绍对象,我们将通过一系列课程教您如何使用ESP8266通过PubSubClient库来实现MQTT物联网应用。关于PubSubClient库,以下是其基本信息:

作者名:Nick O’Leary
官网地址:https://pubsubclient.knolleary.net/
GitHub:https://github.com/knolleary/pubsubclient/
百度网盘下载: https://pan.baidu.com/s/12MHGbdfiOdwOGip5RMSSEQ 提取码: sizy

发布MQTT消息示例程序

通过以下示例程序,我们将可以让ESP8266向公用MQTT服务器发布消息。
下面展示一些 内联代码片

#include <ESP8266WiFi.h>

#include <PubSubClient.h>

#include <Ticker.h>

 

// 设置wifi接入信息(请根据您的WiFi信息进行修改)

const char* ssid = "taichi-maker";

const char* password = "12345678";

const char* mqttServer = "test.ranye-iot.net";

 

// 如以上MQTT服务器无法正常连接,请前往以下页面寻找解决方案

// http://www.taichi-maker.com/public-mqtt-broker/

 

Ticker ticker;

WiFiClient wifiClient;

PubSubClient mqttClient(wifiClient);

 

int count;    // Ticker计数用变量

 

void setup() {

  Serial.begin(9600);

  

  //设置ESP8266工作模式为无线终端模式

  WiFi.mode(WIFI_STA);

  

  // 连接WiFi

  connectWifi();

  

  // 设置MQTT服务器和端口号

  mqttClient.setServer(mqttServer, 1883);

 

  // 连接MQTT服务器

  connectMQTTServer();

 

  // Ticker定时对象

  ticker.attach(1, tickerCount);  

}

 

void loop() {

  if (mqttClient.connected()) { // 如果开发板成功连接服务器

    // 每隔3秒钟发布一次信息

    if (count >= 3){

      pubMQTTmsg();

      count = 0;

    }    

    // 保持心跳

    mqttClient.loop();

  } else {                  // 如果开发板未能成功连接服务器

    connectMQTTServer();    // 则尝试连接服务器

  }

}

 

void tickerCount(){

  count++;

}

 

void connectMQTTServer(){

  // 根据ESP8266的MAC地址生成客户端ID(避免与其它ESP8266的客户端ID重名)

  String clientId = "esp8266-" + WiFi.macAddress();

 

  // 连接MQTT服务器

  if (mqttClient.connect(clientId.c_str())) {

    Serial.println("MQTT Server Connected.");

    Serial.println("Server Address: ");

    Serial.println(mqttServer);

    Serial.println("ClientId:");

    Serial.println(clientId);

  } else {

    Serial.print("MQTT Server Connect Failed. Client State:");

    Serial.println(mqttClient.state());

    delay(3000);

  }  

}

 

// 发布信息

void pubMQTTmsg(){

  static int value; // 客户端发布信息用数字

 

  // 建立发布主题。主题名称以Taichi-Maker-为前缀,后面添加设备的MAC地址。

  // 这么做是为确保不同用户进行MQTT信息发布时,ESP8266客户端名称各不相同,

  String topicString = "Taichi-Maker-Pub-" + WiFi.macAddress();

  char publishTopic[topicString.length() + 1];  

  strcpy(publishTopic, topicString.c_str());

 

  // 建立发布信息。信息内容以Hello World为起始,后面添加发布次数。

  String messageString = "Hello World " + String(value++);

  char publishMsg[messageString.length() + 1];  

  strcpy(publishMsg, messageString.c_str());

  

  // 实现ESP8266向主题发布信息

  if(mqttClient.publish(publishTopic, publishMsg)){

    Serial.println("Publish Topic:");Serial.println(publishTopic);

    Serial.println("Publish message:");Serial.println(publishMsg);    

  } else {

    Serial.println("Message Publish Failed.");

  }

}

 

// ESP8266连接wifi

void connectWifi(){

 

  WiFi.begin(ssid, password);


  //等待WiFi连接,成功连接后输出成功信息

  while (WiFi.status() != WL_CONNECTED) {

    delay(1000);

    Serial.print(".");

  }

  Serial.println("");

  Serial.println("WiFi Connected!");  

  Serial.println("");

}


#include <ESP8266WiFi.h>

#include <PubSubClient.h>

#include <Ticker.h>

 

// 设置wifi接入信息(请根据您的WiFi信息进行修改)

const char* ssid = "taichi-maker";

const char* password = "12345678";

const char* mqttServer = "test.ranye-iot.net";

 
// 如以上MQTT服务器无法正常连接,请前往以下页面寻找解决方案

// http://www.taichi-maker.com/public-mqtt-broker/


Ticker ticker;

WiFiClient wifiClient;

PubSubClient mqttClient(wifiClient);

int count;    // Ticker计数用变量

void setup() {

  Serial.begin(9600);

  //设置ESP8266工作模式为无线终端模式

  WiFi.mode(WIFI_STA);

  // 连接WiFi

  connectWifi();

  // 设置MQTT服务器和端口号

  mqttClient.setServer(mqttServer, 1883);

  // 连接MQTT服务器

  connectMQTTServer();

  // Ticker定时对象

  ticker.attach(1, tickerCount);  

}

void loop() {

  if (mqttClient.connected()) { // 如果开发板成功连接服务器

    // 每隔3秒钟发布一次信息

    if (count >= 3){

      pubMQTTmsg();

      count = 0;

    }    

    // 保持心跳

    mqttClient.loop();

  } else {                  // 如果开发板未能成功连接服务器

    connectMQTTServer();    // 则尝试连接服务器

  }

}

void tickerCount(){

  count++;

}

void connectMQTTServer(){

  // 根据ESP8266的MAC地址生成客户端ID(避免与其它ESP8266的客户端ID重名)

  String clientId = "esp8266-" + WiFi.macAddress();

 

  // 连接MQTT服务器

  if (mqttClient.connect(clientId.c_str())) {

    Serial.println("MQTT Server Connected.");

    Serial.println("Server Address: ");

    Serial.println(mqttServer);

    Serial.println("ClientId:");

    Serial.println(clientId);

  } else {

    Serial.print("MQTT Server Connect Failed. Client State:");

    Serial.println(mqttClient.state());

    delay(3000);
  }  

}

 

// 发布信息

void pubMQTTmsg(){

  static int value; // 客户端发布信息用数字

 

  // 建立发布主题。主题名称以Taichi-Maker-为前缀,后面添加设备的MAC地址。

  // 这么做是为确保不同用户进行MQTT信息发布时,ESP8266客户端名称各不相同,

  String topicString = "Taichi-Maker-Pub-" + WiFi.macAddress();

  char publishTopic[topicString.length() + 1];  

  strcpy(publishTopic, topicString.c_str());

 
  // 建立发布信息。信息内容以Hello World为起始,后面添加发布次数。

  String messageString = "Hello World " + String(value++);

  char publishMsg[messageString.length() + 1];  

  strcpy(publishMsg, messageString.c_str());

  
  // 实现ESP8266向主题发布信息

  if(mqttClient.publish(publishTopic, publishMsg)){

    Serial.println("Publish Topic:");Serial.println(publishTopic);

    Serial.println("Publish message:");Serial.println(publishMsg);    

  } else {
    Serial.println("Message Publish Failed.");
  }
}

// ESP8266连接wifi

void connectWifi(){

  WiFi.begin(ssid, password);
  //等待WiFi连接,成功连接后输出成功信息

  while (WiFi.status() != WL_CONNECTED) {
    delay(1000);
    Serial.print(".");
  }

  Serial.println("");
  Serial.println("WiFi Connected!");  
  Serial.println("");
}


  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

暮誠雪

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值