ESP8266 http GET-запрос не показывает никакого значения в последовательном мониторе - PullRequest
0 голосов
/ 02 мая 2020

У меня есть таблица в базе данных MySQL на моем локальном сервере, и мне удалось отобразить это значение, используя скрипт PHP. Вот скрипт PHP (я назвал его get. php, и он находится прямо в моей папке htdocs в xammp).

<?php
$servername = "localhost";
$username = "root";
$password = "";
$dbname = "mydb";

// Create connection
$conn = new mysqli($servername, $username, $password, $dbname);
// Check connection
if ($conn->connect_error) {
    die("Connection failed: " . $conn->connect_error);
}

$sql = "SELECT reading FROM myread";
$result = $conn->query($sql);

if ($result->num_rows > 0) {
    // output data of each row
    while($row = $result->fetch_assoc()) {
        echo $row["reading"]."<br>";
    }
} else {
    echo "0 results";
}
$conn->close();
?>

, и я также попытался передать эти данные в esp8266, используя код ниже

#include <ESP8266WiFi.h>
#include <WiFiClient.h>
#include <ESP8266WebServer.h>
#include <ESP8266mDNS.h>
#include <ESP8266HTTPClient.h>

int status = WL_IDLE_STATUS;
char server[] = "112.135.74.254";
char ssid[] = "MYWIFI";
char pass[] = "123654MY";
const int httpPort = 80;
float line;
float mililine;

WiFiClient client;

void setup() {
  Serial.begin(9600);

  while (status != WL_CONNECTED) {
    Serial.print("Attempting to connect to Network named: ");
    Serial.println(ssid);
    status = WiFi.begin(ssid, pass);
    delay(10000);
  }

  Serial.print("SSID: ");
  Serial.println(WiFi.SSID());
  IPAddress ip = WiFi.localIP();
  IPAddress gateway = WiFi.gatewayIP();
  Serial.print("IP Address: ");
  Serial.println(ip);


if (!client.connect(server, httpPort)) {
    Serial.println("connection failed");
    return;
  }


  String url = "/get.php";
  Serial.print("requesting URL: ");
  Serial.println(url);

  client.print(String("GET ") + url + " HTTP/1.1\r\n" +
               "Host: " + server + "\r\n" +
               "User-Agent: BuildFailureDetectorESP8266\r\n" +
               "Connection: close\r\n\r\n");



Serial.println("request sent");
  while (client.connected()) {
  String  line = client.readStringUntil('\n');
    if (line == "\r") {
      Serial.println("headers received");
      break;
    }
  }
  Serial.println("reply was:");
  Serial.println("==========");
  Serial.println(line);
  Serial.println("==========");
  Serial.println("closing connection");


 mililine= line * 0.001;
 Serial.println("Final value is - ");
 Serial.println(mililine);

}
void loop() {

}

Но проблема в том, что даже в моей таблице базы данных есть значение (значение 55,25, я имею в виду, что оно также имеет десятичные разряды). Последовательный монитор отображает вывод только как ноль. Вот серийный номер Arduino вывод на монитор

⸮_⸮⸮=s⸮⸮Attempting to connect to Network named: MYWIFI
Attempting to connect to Network named: MYWIFI
Attempting to connect to Network named: MYWIFI
SSID: MYWIFI
IP Address: 192.168.1.102
requesting URL: /get.php
request sent
headers received
reply was:
==========
0.00
==========
closing connection
Final value is - 
0.00

Когда я запускаю скрипт get. php в браузере, он показывает мне значение PHP скрипт показывает значение в браузере . Поэтому мне нужно передать это отображаемое значение на последовательный монитор Arduino. Как я упоминал выше, вместо этого значения отображается ноль. Любая помощь, пожалуйста ???

1 Ответ

0 голосов
/ 03 мая 2020

Я переработал ваш код для использования массивов символов вместо класса String и изменил логику декодирования c. Возможно, он имеет fl aws, потому что я не смог протестировать логи c для вашего скрипта. Если он не выполняет то, что вы хотите, раскомментируйте getDebug () и добавьте комментарий getData () и отправьте результат (начиная с === = DEBUG ====) как изменить ваш вопрос. Если вы получаете ошибку размера буфера, удвойте величину BUFFERSIZE до тех пор, пока она не пройдет.

/*
  Web Server

  A simple webserver getting a value from a database.

  by codebraker007
*/

#include <ESP8266WiFi.h>
#include <WiFiClient.h>
#include <ESP8266WebServer.h>
#include <ESP8266mDNS.h>
#include <ESP8266HTTPClient.h>

const uint16_t BUFFERSIZE = 256;
void sendReq();
void getData();
void getDebug();

char msgBuffer[BUFFERSIZE] = {'\0'};

int status = WL_IDLE_STATUS;
const char ssid[] = "MYWIFI";
const char pass[] = "123654MY";
// Server related vars
const char serverIp[] = "112.135.74.254";
const uint16_t httpPort = 80;
const char  url[] = "/get.php";

float mililine;

WiFiClient client;


void setup() {
  // For serial monitor
  Serial.begin(9600);
  while (!Serial) {
    ; // wait
  }

  while (status != WL_CONNECTED) {
    Serial.print("Attempting to connect to Network named: ");
    Serial.println(ssid);
    status = WiFi.begin(ssid, pass);
    delay(10000);
  }

  Serial.print("SSID: ");
  Serial.println(WiFi.SSID());
  IPAddress ip = WiFi.localIP();
  IPAddress gateway = WiFi.gatewayIP();
  Serial.print("IP Address: ");
  Serial.println(ip);
  Serial.print("Gateway IP Address: ");
  Serial.println(gateway);


  if (!client.connect(serverIp, httpPort)) {
    Serial.println("connection failed");
    return;
  }
  while (client.connected()) {
    sendReq();
    getData();
    //getDebug();
  }

}


void loop() {

}

void sendReq() {
  Serial.print("requesting URL: ");
  Serial.println(url);
  strcpy ( msgBuffer, "GET ");
  strcat ( msgBuffer, url);
  strcat ( msgBuffer, " HTTP/1.1\r\n" );
  strcat ( msgBuffer,  "Host: ");
  strcat ( msgBuffer, serverIp);
  strcat ( msgBuffer, "\r\n");
  strcat ( msgBuffer, "User-Agent: BuildFailureDetectorESP8266\r\n");
  strcat ( msgBuffer, "Connection: close\r\n\r\n");

  client.print(msgBuffer);
  Serial.println("request sent");
}

void getData() {
  bool isHeader = true;
  uint16_t i = 0;
  msgBuffer[0] = '\0';
  if (client.available()) {
    if (i >= BUFFERSIZE) {
      Serial.println("==== DATA READ ERROR ====  /n Enlarge buffer size");
      return;
    }
    char c = client.read();
    if (c != '\r') {
      if (c == '\n' && isHeader ) {
        Serial.println("header received ");
        Serial.println("reply was:");
        Serial.println("==========");
        Serial.println(msgBuffer);
        i = 0;
        msgBuffer[i] = '\0';
        isHeader = false;
      }
      else if (c == '\n' && !isHeader ) {
        Serial.println(msgBuffer);
        Serial.println("==========");

        mililine = atof(msgBuffer) * 0.001;
        Serial.println("Final value is - ");
        Serial.println(mililine);
        Serial.println("==========");
        msgBuffer[i] = '\0';
        i = 0;
      }
      else if ( c != '\n' ) {
        msgBuffer[i] = c;
        i++;
      }
    } //  '\r'
  } // client available
}



void getDebug() {
  uint16_t i = 0;
  msgBuffer[0] = '\0';
  if (client.available()) {
    if (i >= BUFFERSIZE) {
      Serial.println("==== DEBUG ERROR ====  /n Enlarge buffer size");
      return;
    }
    char c = client.read();
    if (c == '\r') {
      msgBuffer[i] = '/';
      i++;
      msgBuffer[i] = 'r';
      i ++;
    }
    else if (c == '\n') {
      msgBuffer[i] = '/';
      i++;
      msgBuffer[i] = 'n';
      i ++;
    }
    else {
      msgBuffer[i] = c;
      i++;
    }
  } // client available
  Serial.println("==== DEBUG ====");
  Serial.println(msgBuffer);
  Serial.println("==========");
}
...