Hardware Software e Internet of Things!

sábado, 8 de diciembre de 2018

Conectar NODEMCU(esp8266) a broker SHIFTR.IO con libreria Pubsubclient - Parte

Conectar NODEMCU (Esp8266) a Broker SHIFTR.IO con librería Pubsubclient - Arduino 

URL DEL SITIO:https://shiftr.io/

La plataforma shiftr.io ha sido creada por Joël Gähwiler como parte de su tesis de maestría "¡Menos pantallas, más objetos!". Se ha desarrollado a partir de la necesidad de una herramienta simple que permita la interconexión de múltiples dispositivos. Además, debería ser tan simple que se pueda utilizar en el contexto educativo y de investigación.
Esta plataforma lo podemos usar como un BROKER GRATUITO para unir nuestros proyectos haciendo uso del protocolo MQTT. En este tutorial les mostrare el proceso para conectarnos con nuestro Modulo NODEMCU (Esp8266) hacia él utilizando la librería de PubSubclient. 

PASOS PREVIOS:
1) Tener Instalado la placa NODEMCU en el IDE ARDUINO

2) Tener Instalado la librería Pubsubclient de Arduino usado para la conexión Vía MQTT, se puede descargar por el gestor de librerías online de Arduino:

Una vez descargado abrir el ejemplo que trae la librería llamada "mqtt_esp8266"



PROCEDIMIENTO:
1) Para empezar a usarlo debemos crearnos una cuenta aqui https://shiftr.io/sign-up, lo cual es muy sencillo y loguearnos en el y se mostra una interface como esta:


2) Para crear un "Namespace" o "broker" tenemos que dirigirnos en este botón y dar clic en "New Namespace" :



 el cual nos redirigira a una ventada nueva donde deberemos colocar un nombre al "Namespace " o "borker" que estamos creando, yo le coloque mi nombre como <Marko-Antonio>, luego dar en "Create Namspace". La Opción de "privado es opcional y sirve para que ningun otro usuario de Shiftr.io logre encontrar este broker que estamos creando.

3) Una vez creado el "Namespace", nos muestra  nuestro broker simbolizado por un circulo, (aun no tiene conexiones). Lo siguiente es configurar el "token" o los datos para que nuestros dispositivos se autentiquen, para eso debemos dar clic en "Namespace Settings".


 Clic en "add Token"


y luego debemos de asiganr un "username" y un "password", y luego dar clic en "Create Token":

Ya tenemos configurado nuestro broker con autenticacion!, ahora debemos dirigirnos a nuestro broker, dando clic en su nombre,  para observar las conexiones de los dispositivos en él:

Podemos observar el broker, ahora solo nos queda conectarnos hacia el con la NODEMCU haciendo usao de la libreria pubsubclient, previo a eso deberemos colocar los accesos como públicos , en el se vera el resumen de la conexio: el primero Username, Password, y el dominio del Broker,


4) Ahora solo queda conectar Nuestra NODEMCU CON EL CODIGO QUE ADJUNTO: Aqui debemoms modificar el Username y el password por el que corresponede al que hayamos creado

RESUMEN DE  CONFIGURACIO DE MI BROKER:
mqtt://marko987:987marko@broker.shiftr.io
USERNAME: marko987
PASSWORD: 987marko
SERVER: broker.shiftr.io


CODIGO ARDUINO NODEMCU  USANDO LIBRERIA PUBSUBCLIENT



/*
 Basic ESP8266 MQTT example

 This sketch demonstrates the capabilities of the pubsub library in combination
 with the ESP8266 board/library.

 It connects to an MQTT server then:
  - publishes "hello world" to the topic "outTopic" every two seconds
  - subscribes to the topic "inTopic", printing out any messages
    it receives. NB - it assumes the received payloads are strings not binary
  - If the first character of the topic "inTopic" is an 1, switch ON the ESP Led,
    else switch it off

 It will reconnect to the server if the connection is lost using a blocking
 reconnect function. See the 'mqtt_reconnect_nonblocking' example for how to
 achieve the same result without blocking the main loop.

 To install the ESP8266 board, (using Arduino 1.6.4+):
  - Add the following 3rd party board manager under "File -> Preferences -> Additional Boards Manager URLs":
       http://arduino.esp8266.com/stable/package_esp8266com_index.json
  - Open the "Tools -> Board -> Board Manager" and click install for the ESP8266"
  - Select your ESP8266 in "Tools -> Board"

*/

#include <ESP8266WiFi.h>
#include <PubSubClient.h>

// Update these with values suitable for your network.

const char* ssid = "HUAWEI-73ED";  ///CAMBIAR AQUI EL NOMBRE DEL WIFI
const char* password = "04592945"; //CAMBIAR AQUI EL PASSWORD DEL WIFI
const char* mqtt_server = "broker.shiftr.io";  //COLOCAMOS AQUI EL DOMINIO DEL BROKER

///////////////////////AUTENTICACION BROKER MQTT///////////////////////////////////////////
const char clientID[]="Marko-Antonio";  //CAMBIAMOS AQUI EL ID DEL CLIENTE
const char username[]="marko987";      //CAMBIAMOS AQUI POR EL "USERNAME" CONFIGURADO EL SHIFTR.IO
const char passwords[]="987marko";       //CAMBIAMOS AQUI POR EL "PASSWORD" CONFIGURADO EL SHIFTR.IO
const char willTopic[]= "";               //WILL TOPIC
int willQoS=0;                             // CALIDAD DE SERVICIO 0-1-2
int  willRetain=0 ;                         //0-1  //si se activa o no la retencion de data
const char willMessage[]="";    //mensaje cuando device este desconectado de broker
////////////////////////////////////////////////////////////////////////////////////////////////


WiFiClient espClient;
PubSubClient client(espClient);
long lastMsg = 0;
char msg[50];
int value = 0;

void setup_wifi() {

  delay(10);
  // We start by connecting to a WiFi network
  Serial.println();
  Serial.print("Connecting to ");
  Serial.println(ssid);

  WiFi.begin(ssid, password);

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

  randomSeed(micros());

  Serial.println("");
  Serial.println("WiFi connected");
  Serial.println("IP address: ");
  Serial.println(WiFi.localIP());
}

void callback(char* topic, byte* payload, unsigned int length) {
  Serial.print("Message arrived [");
  Serial.print(topic);
  Serial.print("] ");
  for (int i = 0; i < length; i++) {
    Serial.print((char)payload[i]);
  }
  Serial.println();

  // Switch on the LED if an 1 was received as first character
  if ((char)payload[0] == '1') {
    digitalWrite(BUILTIN_LED, LOW);   // Turn the LED on (Note that LOW is the voltage level
    // but actually the LED is on; this is because
    // it is active low on the ESP-01)
  } else {
    digitalWrite(BUILTIN_LED, HIGH);  // Turn the LED off by making the voltage HIGH
  }

}

void reconnect() {
  // Loop until we're reconnected
  while (!client.connected()) {
    Serial.print("Attempting MQTT connection...");
    // Create a random client ID
    String clientId = "ESP8266Client-";
    clientId += String(random(0xffff), HEX);
    // Attempt to connect
    //if (client.connect(clientId.c_str())) {
      if(client.connect(clientID,username,passwords,willTopic,willQoS,willRetain,willMessage)){
      Serial.println("connected");
      // Once connected, publish an announcement...
      client.publish("outTopic", "hello world");
      // ... and resubscribe
      client.subscribe("inTopic");
    } else {
      Serial.print("failed, rc=");
      Serial.print(client.state());
      Serial.println(" try again in 5 seconds");
      // Wait 5 seconds before retrying
      delay(5000);
    }
  }
}

void setup() {
  pinMode(BUILTIN_LED, OUTPUT);     // Initialize the BUILTIN_LED pin as an output
  Serial.begin(115200);
  setup_wifi();
  client.setServer(mqtt_server, 1883);
  client.setCallback(callback);
}

void loop() {

  if (!client.connected()) {
    reconnect();
  }
  client.loop();

  long now = millis();
  if (now - lastMsg > 2000) {
    lastMsg = now;
    ++value;
    snprintf (msg, 50, "hello world #%ld", value);
    Serial.print("Publish message: ");
    Serial.println(msg);
    client.publish("outTopic", msg);
  }
}



CONEXIÓN EXITOSA!




Share:

0 comentarios:

Publicar un comentario

Seguidores

Datos personales

Entradas populares