Dragino LG01-S收到异常的数据包并停止工作

时间:2018-08-13 09:14:21

标签: c++ arduino esp32 lora lorawan

Dragino LG01-S与Heltec WiFi LoRa 32之间的连接出现问题。

WiFi LoRa 32每5秒将带有温度数据的数据包发送到LG01-S。 LG01-S不断接收数据包,但是过了一段时间(可能是20分钟,可能是7个小时),它收到了一个与其他数据包不同的数据包。我跟踪了串行监视器中的数据包,直到出现故障为止,这就是我看到的样子。

“失败”数据包如下所示:

¹h260äàŽÛNR·à,ªê@��ö9AÚ�o...Œ?ÚK;ËÍ×.Ü*!®d§“ ¿'ZoL

通常是这样的:

30.00

普通数据包的大小为5个字节,而失败数据包的大小为73个字节。

故障发生在接收器(LG01-S)中,因为在出​​现故障数据包之后,它只是停止接收任何数据并且根本不执行任何代码。失败后,LoRa32继续发送数据包。

我检查了故障是否一致,但不是一致的,如上所述,它们在不同的时间发生。

下面您可以看到发送者和接收者的代码。

发件人

    #include <SPI.h>
#include <LoRa.h>
#include "SSD1306.h"
#include<Arduino.h>
#include <dht.h>


SSD1306  display(0x3c, 4, 15);

#define DHTPIN  17

#define SS      18
#define RST     14
#define DI0     26
#define BAND    915E6

//create an instance of DHT sensor
dht TempSensor;

void setup()
{
  pinMode(16, OUTPUT);
  digitalWrite(16, LOW);
  delay(50);
  digitalWrite(16, HIGH);

  Serial.begin(115200);
  while (!Serial);
  display.init();
  display.flipScreenVertically();
  display.setFont(ArialMT_Plain_10);
  display.setTextAlignment(TEXT_ALIGN_LEFT);
  display.drawString(5, 5, "LoRa Sender");
  display.display();

  SPI.begin(5, 19, 27, 18);
  LoRa.setPins(SS, RST, DI0);
  Serial.println("LoRa Sender");
  if (!LoRa.begin(BAND)) {
    Serial.println("Starting LoRa failed!");
    while (1);
  }

  LoRa.setSyncWord(0xF3);
  Serial.println("LoRa Initial OK!");
  display.drawString(5, 20, "LoRa Initializing OK!");
  display.display();
  delay(2000);
}

void loop() {
  double check = TempSensor.read11(DHTPIN);
  Serial.println(TempSensor.temperature);
  Serial.print("Sending temperature: ");
  Serial.println(TempSensor.temperature);
  display.clear();
  display.setFont(ArialMT_Plain_16);
  display.drawString(3, 5, "Sending temperature ");
  display.drawString(50, 30, String(TempSensor.temperature));
  display.display();
  // sending packet
  LoRa.beginPacket();
  LoRa.print(TempSensor.temperature);
  Serial.println("package sent");
  LoRa.endPacket();
  delay(5000);
}

接收器:

#include <SPI.h>
#include <LoRa.h>
#include <Console.h>
#include <Process.h>
#include <Bridge.h>

// Set center frequency
uint32_t freq = 915E6;
Process logdata;
int timeCounter = 0;
void setup() {
  Bridge.begin(115200);
  Console.begin();
  Console.println("LoRa Receiver");

  if (!LoRa.begin(freq)) {
    Console.println("Starting LoRa failed!");
    while (1);
  }
  LoRa.setSyncWord(0xF3);
  LoRa.receive();
}

void loop() {
  // try to parse packet
  int packetSize = LoRa.parsePacket();
  if (packetSize) {
    // received a packet read packet
    while (LoRa.available()) {
      String TemperatureData = LoRa.readString();
      Console.println(TemperatureData);
      Console.println(packetSize);
      //Save in db
      logdata.begin("lua");
      logdata.addParameter("/root/LinkTempInside.lua");  //
      logdata.addParameter(String(TemperatureData));  //
      logdata.run();  // run the command

      // read the output of the command
      while (logdata.available() > 0) {
        char c = logdata.read();
      }
      Console.println("Data Sent");
    }
  }
}

谢谢您的帮助。

1 个答案:

答案 0 :(得分:0)

LoRa是一种共享介质,因此您希望从自己的设备和外部设备接收数据包。您必须验证您使用的是正确的软件包。

最好的方法是使用LoRaWAN协议,该协议允许通过设备地址和消息完整性代码来验证数据包的来源。