
本文旨在帮助解决Arduino通过PHP脚本向数据库传输数据时,PHP接收到的变量值始终为”0″的问题。通过分析Arduino代码中的HTTP请求构建方式,提供正确的代码示例,确保数据能够正确地从Arduino发送到PHP脚本,并最终存储到数据库中。
在将Arduino传感器数据传输到数据库时,常见的问题是数据在传输过程中丢失或损坏。以下是解决此问题的详细步骤和注意事项。
分析问题
从问题描述中,可以确定以下几点:
- PHP脚本能够正常连接到数据库。
- 直接在PHP脚本中插入固定值可以成功写入数据库。
- Arduino代码能够连接到网络。
- 问题出在Arduino向PHP脚本发送变量数据的过程中。
关键在于理解HTTP GET请求的正确格式。
立即学习“PHP免费学习笔记(深入)”;
解决方案
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脚本向数据库发送数据时遇到的问题的详细内容,更多请关注php中文网其它相关文章!