Firebase Realtime Database จัดเก็บและซิงโครไนซ์ข้อมูลโดยใช้ฐานข้อมูลบนคลาวด์ NoSQL ข้อมูลจะซิงโครไนซ์กับไคลเอนต์ทั้งหมดแบบเรียลไทม์ และยังคงใช้งานได้เมื่อแอปของคุณออฟไลน์
ก่อนที่คุณจะเริ่มต้น
ก่อนที่คุณจะสามารถใช้ Firebase Realtime Database คุณต้อง:
ลงทะเบียนโปรเจ็กต์ C++ ของคุณและกำหนดค่าให้ใช้ Firebase
หากโปรเจ็กต์ C++ ของคุณใช้ Firebase อยู่แล้ว แสดงว่ามีการลงทะเบียนและกำหนดค่าสำหรับ Firebase แล้ว
เพิ่ม Firebase C++ SDK ในโครงการ C++ ของคุณ
โปรดทราบว่าการเพิ่ม Firebase ในโปรเจ็กต์ C++ ของคุณเกี่ยวข้องกับงานทั้งใน คอนโซล Firebase และในโปรเจ็กต์ C++ แบบเปิดของคุณ (เช่น คุณดาวน์โหลดไฟล์กำหนดค่า Firebase จากคอนโซล จากนั้นย้ายไฟล์เหล่านี้ไปยังโปรเจ็กต์ C++)
สร้างฐานข้อมูล
ไปที่ส่วน ฐานข้อมูลเรียลไทม์ ของ คอนโซล Firebase คุณจะได้รับแจ้งให้เลือกโปรเจ็กต์ Firebase ที่มีอยู่ ทำตามขั้นตอนการสร้างฐานข้อมูล
เลือกโหมดเริ่มต้นสำหรับกฎความปลอดภัยของ Firebase:
- โหมดทดสอบ
เหมาะสำหรับการเริ่มต้นใช้งานไลบรารีไคลเอ็นต์บนมือถือและเว็บ แต่อนุญาตให้ทุกคนอ่านและเขียนทับข้อมูลของคุณได้ หลังจากการทดสอบ อย่าลืมทบทวนส่วน ทำความเข้าใจกฎฐานข้อมูลเรียลไทม์ของ Firebase
หากต้องการเริ่มต้นใช้งานเว็บ Apple หรือ Android SDK ให้เลือกโหมดทดสอบ
- โหมดล็อค
ปฏิเสธการอ่านและเขียนทั้งหมดจากไคลเอนต์มือถือและเว็บ เซิร์ฟเวอร์แอปพลิเคชันที่ผ่านการรับรองความถูกต้องของคุณยังคงสามารถเข้าถึงฐานข้อมูลของคุณได้
เลือกตำแหน่งสำหรับฐานข้อมูล
ขึ้นอยู่กับ ตำแหน่งของฐานข้อมูล URL สำหรับฐานข้อมูลใหม่จะอยู่ในรูปแบบใดรูปแบบหนึ่งต่อไปนี้:
DATABASE_NAME .firebaseio.com
(สำหรับฐานข้อมูลในus-central1
)DATABASE_NAME . REGION .firebasedatabase.app
(สำหรับฐานข้อมูลในตำแหน่งอื่นทั้งหมด)
คลิก เสร็จสิ้น
เมื่อคุณเปิดใช้ Realtime Database จะเป็นการเปิดใช้งาน API ใน Cloud API Manager ด้วย
สร้างและเริ่มต้น firebase::App
ก่อนที่คุณจะสามารถเข้าถึงฐานข้อมูลเรียลไทม์ได้ คุณจะต้องสร้างและเริ่มต้น firebase::App
รวมไฟล์ส่วนหัวสำหรับ firebase::App
:
#include "firebase/app.h"
แอนดรอยด์
สร้าง firebase::App
ผ่านสภาพแวดล้อม JNI และการอ้างอิง jobject
ไปยัง Java Activity เป็นอาร์กิวเมนต์:
app = ::firebase::App::Create(::firebase::AppOptions("APPLICATION NAME"), jni_env, activity);
iOS+
สร้าง firebase::App
:
app = ::firebase::App::Create(::firebase::AppOptions("APPLICATION NAME"));
เข้าถึง firebase::database::Database Class
firebase::database::Database
เป็นจุดเริ่มต้นสำหรับ Firebase Realtime Database C++ SDK
::firebase::database::Database *database = ::firebase::database::Database::GetInstance(app);
หากคุณเลือกที่จะใช้การเข้าถึงแบบสาธารณะสำหรับกฎของคุณ คุณสามารถดำเนินการต่อในส่วนที่เกี่ยวกับการบันทึกและดึงข้อมูล
การตั้งค่าการเข้าถึงที่จำกัด
หากคุณไม่ต้องการใช้การเข้าถึงแบบสาธารณะ คุณสามารถเพิ่ม Firebase Authentication ในแอปของคุณเพื่อควบคุมการเข้าถึงฐานข้อมูล
ขั้นตอนถัดไป
เรียนรู้วิธี จัดโครงสร้างข้อมูล สำหรับ Realtime Database
เตรียมเปิดตัวแอปของคุณ:
- ตั้งค่า การแจ้งเตือนงบประมาณ สำหรับโครงการของคุณใน Google Cloud Console
- ตรวจสอบ แดชบอร์ด การใช้งานและการเรียกเก็บเงิน ในคอนโซล Firebase เพื่อดูภาพรวมของการใช้งานโครงการของคุณในบริการต่างๆ ของ Firebase คุณยังสามารถเยี่ยมชม แดชบอร์ด การใช้งาน ฐานข้อมูลเรียลไทม์ เพื่อดูข้อมูลการใช้งานโดยละเอียดเพิ่มเติม
- ตรวจสอบ รายการตรวจสอบการเปิดใช้ Firebase
ปัญหาที่ทราบ
- บนแพลตฟอร์มเดสก์ท็อป (Windows, Mac, Linux) Firebase C++ SDK ใช้ REST เพื่อเข้าถึงฐานข้อมูลของคุณ ด้วยเหตุนี้ คุณต้อง ประกาศดัชนีที่คุณใช้ กับ Query::OrderByChild() บนเดสก์ท็อป มิฉะนั้น Listener ของคุณจะล้มเหลว
- เวอร์ชันเวิร์กโฟลว์บนเดสก์ท็อปของ Realtime Database ไม่รองรับการทำงานแบบออฟไลน์หรือการคงอยู่