解决Arduino通过PHP脚本向数据库发送数据时遇到的问题(脚本.发送.数据库.解决.数据...)

wufei1232025-07-26PHP1

解决arduino通过php脚本向数据库发送数据时遇到的问题

本文旨在帮助解决Arduino通过PHP脚本向数据库传输数据时,PHP接收到的变量值始终为"0"的问题。通过分析Arduino代码中的HTTP请求构建方式,提供正确的代码示例,确保数据能够正确地从Arduino发送到PHP脚本,并最终存储到数据库中。

在将Arduino传感器数据传输到数据库时,常见的问题是数据在传输过程中丢失或损坏。以下是解决此问题的详细步骤和注意事项。

分析问题

从问题描述中,可以确定以下几点:

  • PHP脚本能够正常连接到数据库。
  • 直接在PHP脚本中插入固定值可以成功写入数据库。
  • Arduino代码能够连接到网络。
  • 问题出在Arduino向PHP脚本发送变量数据的过程中。

关键在于理解HTTP GET请求的正确格式。

解决方案

Arduino代码中构建HTTP请求的方式存在问题。正确的GET请求应该将参数附加到URL后面,而不是作为Content-Length发送。

以下是修改后的Arduino代码:

#include <SPI.h>
#include <Ethernet.h>
#define POWER_PIN_WATER_SENS 7
#define SIGNAL_PIN_WATER_SENS A5
#define SOUND_PIN A0
byte mac[] = {0x00, 0xAA, 0xBB, 0xCC, 0xDE, 0x02};
int waterLevel = 0;
String waterLevelString;     
EthernetClient client;
void setup() {

  Serial.begin(9600);
  pinMode(POWER_PIN_WATER_SENS,OUTPUT);
  digitalWrite(POWER_PIN_WATER_SENS, LOW);  
  Serial.println("Initialize Ethernet with DHCP:");
  if (Ethernet.begin(mac) == 0) {
    Serial.println("Failed to configure Ethernet using DHCP");
    if (Ethernet.hardwareStatus() == EthernetNoHardware) {
      Serial.println("Ethernet shield was not found.  Sorry, can't run without hardware. :(");
    } else if (Ethernet.linkStatus() == LinkOFF) {
      Serial.println("Ethernet cable is not connected.");
    }
    while (true) {
      delay(1);
    }
  }
  Serial.print("My IP address: ");
  Serial.println(Ethernet.localIP());
}

void loop() {
  switch (Ethernet.maintain()) {
    case 1:
      //renewed fail
      Serial.println("Error: renewed fail");
      break;

    case 2:
      //renewed success
      Serial.println("Renewed success");
      //print your local IP address:
      Serial.print("My IP address: ");
      Serial.println(Ethernet.localIP());
      break;

    case 3:
      //rebind fail
      Serial.println("Error: rebind fail");
      break;

    case 4:
      //rebind success
      Serial.println("Rebind success");
      //print your local IP address:
      Serial.print("My IP address: ");
      Serial.println(Ethernet.localIP());
      break;

    default:
      //nothing happened
      break;
  }
  digitalWrite(POWER_PIN_WATER_SENS, HIGH);
  delay(100);
  waterLevel = analogRead(SIGNAL_PIN_WATER_SENS);
  digitalWrite(POWER_PIN_WATER_SENS, LOW);
  Serial.print("Water: ");
  //waterLevel = 1; //debug value
  Serial.println(waterLevel);
  waterLevelString = "waterlevel=" + (String)waterLevel;


    if (client.connect("<snip>", 80)) {
    client.print("GET /arduino_connect_to_db.php?");
    client.print(waterLevelString);
    client.println(" HTTP/1.1");
    client.println("Host: <snip>");
    client.println("User-Agent: arduino");
    client.println("Accept: */*");
    client.println();
  }
    if (client.connected()) { 
    client.stop();
  }
    delay(3000);
  }

关键修改:

  • 将client.print("Content-Type: application/x-www-form-urlencoded"); 和 client.print("Content-Length: "); 相关代码移除。
  • 将client.print(waterLevelString); 附加到URL之后,形成正确的GET请求。
  • 添加User-Agent和Accept头,提高兼容性。
代码解释
  • client.print("GET /arduino_connect_to_db.php?");:这行代码开始构建GET请求,指定要访问的PHP脚本。
  • client.print(waterLevelString);:这行代码将包含水位数据的字符串附加到URL后面,作为GET请求的参数。例如,如果waterLevelString的值是"waterlevel=123",那么最终的URL将是/arduino_connect_to_db.php?waterlevel=123。
  • client.println(" HTTP/1.1");:这行代码指定HTTP协议版本。
  • client.println("Host: ");:这行代码指定服务器的主机名。
  • client.println("User-Agent: arduino");:这行代码指定客户端的User-Agent,方便服务器识别客户端类型。
  • client.println("Accept: */*");:这行代码指定客户端接受的MIME类型。
注意事项
  • 确保Arduino能够正确连接到网络,并且能够访问到PHP脚本所在的服务器。
  • 检查PHP脚本中的数据库连接信息是否正确。
  • 在Arduino代码中,将替换为你的服务器的实际域名或IP地址。
  • 确保数据库表waterLevelTable中存在waterlevel字段,并且字段类型与Arduino发送的数据类型兼容。
  • 在调试过程中,可以使用串口监视器打印Arduino发送的数据,以便检查数据是否正确。
总结

通过修改Arduino代码中构建HTTP请求的方式,可以解决Arduino通过PHP脚本向数据库发送数据时遇到的问题。正确的GET请求应该将参数附加到URL后面,而不是作为Content-Length发送。同时,需要注意网络连接、数据库连接和数据类型等问题,以确保数据能够正确地从Arduino发送到PHP脚本,并最终存储到数据库中。

以上就是解决Arduino通过PHP脚本向数据库发送数据时遇到的问题的详细内容,更多请关注知识资源分享宝库其它相关文章!

发表评论

访客

◎欢迎参与讨论,请在这里发表您的看法和观点。