本文介绍从零开始搭建轻量级服务器,接收 arduino 通过 http 或 mqtt 上报的传感器数据,并将其持久化至 sqlite 数据库,供 java 应用实时读取与分析的完整实践路径。
构建一个可靠的数据通道,将 Arduino 采集的温湿度、光照、加速度等传感器数据上传至服务器,并被 Java 后端应用安全、高效地消费,是物联网项目中的典型需求。整个链路可分为三部分:Arduino 端数据上报 → 服务端接收与存储 → Java 应用查询使用。以下为可落地的技术方案:
你已注册域名(如 yourdomain.com),接下来需一台可公网访问的服务器。推荐选择:
✅ 示例:在 Ubuntu 上快速启动一个接收端(使用 Flask): # server.py from flask import Flask, request, jsonify import sqlite3 import time
app = Flask(name)
def init_db(): conn = sqlite3.connect('sensors.db') conn.execute('''CREATE TABLE IF NOT EXISTS readings ( id INTEGER PRIMARY KEY AUTOINCREMENT, device_id TEXT NOT NULL, temperature REAL, humidity REAL, timestamp DATETIME DEFAULT CURRENT_TIMESTAMP )''') conn.commit() conn.close()
@app.route('/api/sensor', methods=['POST']) def receive_sensor(): try: data = request.get_json() conn = sqlite3.connect('sensors.db') conn.execute( "INSERT INTO readings (device_id, temperature, humidity) VALUES (?, ?, ?)", (data['device_id'], data['temp'], data['humi']) ) conn.commit() conn.close() return jsonify({"status": "success"}), 200 except Exception as e: return jsonify({"error": str(e)}), 400
if name == 'main': init_db() app.run(host='0.0.0.0:5000') # 生产环境请用 Gunicorn + Nginx
运行后,Arduino可通过 HTTP POST 发送 JSON 数据: ```cpp // Arduino ESP32 示例(使用 WiFiClientSecure) const char* server = "yourdomain.com"; http.begin(client, "https://" + String(server) + "/api/sensor"); http.addHeader("Content-Type", "application/json"); String json = "{\"device_id\":\"esp32-01\",\"temp\":24.5,\"humi\":62.3}"; int httpCode = http.POST(json);
Java 侧无需额外服务,直接通过 JDBC 访问同步到本地或远程 SQLite 文件(注意:SQLite 不支持多进程高并发写入,生产中建议服务端提供 REST API 供 Java 调用):
// Java 查询示例(使用 sqlite-jdbc)
String url = "jdbc:sqlite:sensors.db";
try (Connection conn = DriverManager.getConnection(url);
Statement stmt = conn.createStatement();
ResultSet rs = stmt.executeQuery("SELECT * FROM readings ORDER BY timestamp DESC LIMIT 10")) {
while (rs.next()) {
System.out.printf("Device: %s | Temp: %.1f°C | Time: %s%n",
rs.getString("device_id"),
rs.getDouble("temperature"),
rs.getString("timestamp"));
}
}整套方案兼顾成本、可控性与可扩展性——从 GoDaddy 域名出发,仅需 1 小时即可完成端到端验证。后续可按需加入用户认证、数据可视化(如 Grafana)、告警推送等功能。