Sim808 GPRS モジュールと Arduino UNO を使用して Cloud Firestore データベースにデータを送信したいと考えています。
Arduinoにアップロードしたコードは次のとおりです。
#include <DFRobot_sim808.h>
#include <SoftwareSerial.h>
#define PIN_TX 10
#define PIN_RX 11
SoftwareSerial mySerial(PIN_TX,PIN_RX);
DFRobot_SIM808 sim808(&mySerial);//Connect RX,TX,PWR,
char http_cmd[] = "GET /add?lat=45.23164&long=42.45737&date=29.01.2020 HTTP/1.0\r\n\r\n";
char buffer2[512];
void setup(){
mySerial.begin(9600);
Serial.begin(9600);
//******** Initialize sim808 module *************
while(!sim808.init()) {
delay(1000);
Serial.print("Sim808 init error\r\n");
}
delay(3000);
//*********** Attempt DHCP *******************
while(!sim808.join(F("cmnet"))) {
Serial.println("Sim808 join network error");
delay(2000);
}
//************ Successful DHCP ****************
Serial.print("IP Address is ");
Serial.println(sim808.getIPAddress());
//*********** Establish a TCP connection ************
if(!sim808.connect(TCP,"us-central1-myprojectname.cloudfunctions.net", 80)) {
Serial.println("Connect error");
}else{
Serial.println("Connect mbed.org success");
}
//*********** Send a GET request *****************
Serial.println("waiting to fetch...");
sim808.send(http_cmd, sizeof(http_cmd)-1);
while (true) {
int ret = sim808.recv(buffer2, sizeof(buffer2)-1);
if (ret <= 0){
Serial.println("fetch over...");
break;
}
buffer2[ret] = '\0';
Serial.print("Recv: ");
Serial.print(ret);
Serial.println(" bytes: ");
Serial.println(buffer2);
break;
}
//************* Close TCP or UDP connections **********
sim808.close();
//*** Disconnect wireless connection, Close Moving Scene *******
sim808.disconnect();
}
void loop(){
}
次に、Firebase CLI を使用して Firebase Functions プロジェクトを作成し、index.js ファイルに記述したコードは次のとおりです。
const functions = require('firebase-functions');
const admin = require('firebase-admin');
const express = require('express');
const app = express();
admin.initializeApp();
var fs = admin.firestore();
app.get("/",(req,res)=>{
var lat = req.param("lat");
var long = req.param("long");
var date = req.param("date");
fs.collection("locations").add({
"date":date,
"lat":lat,
"long":long
}).then(()=>{
res.send("Location :"+lat+","+long);
return null;
}).catch((err)=>{
console.log(err);
res.send("Error");
});
});
exports.add = functions.https.onRequest(app);
次に、「firebase-deploy」コマンドを使用してリンクを取得します。プロジェクト コンソール リンクは次のようになります。
最後にシリアルポートの画面でArduino UNOを見ます。しかし、404 (Not Found) エラーが発生します。
注 : ブラウザでリンクに移動すると、Firestore データベースに新しいレコードを追加できます。
404 (Not Found) エラーが発生したのはなぜですか? 手伝って頂けますか?前もって感謝します。