0

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) エラーが発生したのはなぜですか? 手伝って頂けますか?前もって感謝します。

4

1 に答える 1