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

DDD
发布: 2025-07-21 18:24:11
原创
239人浏览过

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

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

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

分析问题

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

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

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

立即学习PHP免费学习笔记(深入)”;

怪兽AI数字人
怪兽AI数字人

数字人短视频创作,数字人直播,实时驱动数字人

怪兽AI数字人 44
查看详情 怪兽AI数字人

解决方案

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: <snip>");:这行代码指定服务器的主机名。
  • client.println("User-Agent: arduino");:这行代码指定客户端的User-Agent,方便服务器识别客户端类型。
  • client.println("Accept: */*");:这行代码指定客户端接受的MIME类型。

注意事项

  • 确保Arduino能够正确连接到网络,并且能够访问到PHP脚本所在的服务器。
  • 检查PHP脚本中的数据库连接信息是否正确。
  • 在Arduino代码中,将<snip>替换为你的服务器的实际域名或IP地址。
  • 确保数据库表waterLevelTable中存在waterlevel字段,并且字段类型与Arduino发送的数据类型兼容。
  • 在调试过程中,可以使用串口监视器打印Arduino发送的数据,以便检查数据是否正确。

总结

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

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

PHP速学教程(入门到精通)
PHP速学教程(入门到精通)

PHP怎么学习?PHP怎么入门?PHP在哪学?PHP怎么学才快?不用担心,这里为大家提供了PHP速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号