Expo大作戰(十六)--expo結合firebase 一個nosql資料庫(本章令我驚訝但又失望!)

来源:https://www.cnblogs.com/gdsblog/archive/2018/03/13/8563091.html
-Advertisement-
Play Games

簡要:本系列文章講會對expo進行全面的介紹,本人從2017年6月份接觸expo以來,對expo的研究斷斷續續,一路走來將近10個月,廢話不多說,接下來你看到內容,講全部來與官網 我猜去全部機翻+個人修改補充+demo測試的形式,對expo進行一次大補血!歡迎加入expo興趣學習交流群:597732 ...


簡要:本系列文章講會對expo進行全面的介紹,本人從2017年6月份接觸expo以來,對expo的研究斷斷續續,一路走來將近10個月,廢話不多說,接下來你看到內容,講全部來與官網

我猜去全部機翻+個人修改補充+demo測試的形式,對expo進行一次大補血!歡迎加入expo興趣學習交流群:597732981

【之前我寫過一些列關於expo和rn入門配置的東i西,大家可以點擊這裡查看:從零學習rn開發

相關文章:

Expo大作戰(一)--什麼是expo,如何安裝expo clinet和xde,xde如何使用

Expo大作戰(二)--expo的生命周期,expo社區交流方式,expo學習必備資源,開發使用expo時關註的一些問題

Expo大作戰(三)--針對已經開發過react native項目開發人員有針對性的介紹了expo,expo的局限性,開發時項目選型註意點等

Expo大作戰(四)--快速用expo構建一個app,expo中的關鍵術語

Expo大作戰(五)--expo中app.json 文件的配置信息

Expo大作戰(六)--expo開發模式,expo中exp命令行工具,expo中如何查看日誌log,expo中的調試方式

Expo大作戰(七)--expo如何使用Genymotion模擬器

Expo大作戰(八)--expo中的publish以及expo中的link,對link這塊東西沒有詳細看,大家可以來和我交流

更多>>

接下來就開始擼碼


使用Firebase

Firebase資料庫是一款流行的NoSQL雲資料庫,它允許開發人員實時同步實時數據。通過多平臺支持,在用戶和客戶端之間同步數據是非常無縫的,但如果您不關心實時更新,它也可以更普遍地用作通用持久性NoSQL數據支持。它具有非常靈活的規則語法,可以對數據訪問進行微小的控制。

幸運的是,從3.1+版本開始的Firebase JavaScript SDK幾乎全面支持React Native,因此將其添加到我們的expo應用程式中非常簡單。本指南後面介紹的一點是,通常由Firebase SDK提供的用戶登錄組件不適用於React Native,因此我們必須解決它。

有關更多一般信息,請參閱firebase.google.com/docs/database,並且官方Firebase博客文章宣佈React Native相容性

註意:本指南僅涵蓋Firebase實時資料庫,並不包含Google Firebase規模較大的其他服務。 Firebase雲存儲目前不受支持,但我們正在努力將Blob實現上行到React Native,從而使其成為可能。有關為什麼不支持其他Firebase服務的更多背景信息,請閱讀Brent Vatne對Canny的回覆

1. Firebase SDK設置

首先,我們需要設置Firebase帳戶並創建一個新項目。 我們將使用Firebase提供的JavaScript SDK,將其納入您的expo項目。

npm install --save firebase

Firebase控制台會為您提供一個API密鑰以及您的項目初始化所需的其他標識符。 firebase-web-start詳細描述了每個欄位在控制臺中的含義以及在哪裡可以找到它們。

import * as firebase from 'firebase';

// Initialize Firebase
const firebaseConfig = {
  apiKey: "<YOUR-API-KEY>",
  authDomain: "<YOUR-AUTH-DOMAIN>",
  databaseURL: "<YOUR-DATABASE-URL>",
  storageBucket: "<YOUR-STORAGE-BUCKET>"
};

firebase.initializeApp(firebaseConfig);

臨時繞過預設安全規則(Temporarily Bypass Default Security Rules)

預設情況下,Firebase資料庫具有安全規則設置,以便所有訪問您數據的設備都必須通過身份驗證。 我們顯然還沒有設置任何身份驗證,所以我們現在可以在我們設置應用程式的其餘部分時禁用它。

進入Firebase的資料庫控制台,在“規則”選項卡下,您應該看到已經為您提供的一組預設規則。 將規則更改為:

{
  "rules": {
    ".read": true,
    ".write": true
  }
}

請參閱示例Firebase規則以獲取適用於您的數據的良好規則集,包括未經身份驗證的規則。

註意重要的是要註意,這對於開發來說是暫時的,在發佈應用程式之前應對這些規則進行徹底評估。

2.存儲數據和接收更新

通過Firebase存儲數據可能非常簡單。 想象一下,我們正在創建一個高分存儲在Firebase中供所有人查看的游戲。 我們可以在每個用戶引用的數據中創建一個用戶存儲桶。 設置他們的高分將是直截了當的。

function storeHighScore(userId, score) {
  firebase.database().ref('users/' + userId).set({
    highscore: score
  });
}

現在讓我們假設我們希望另一個客戶端收聽特定用戶的高分的更新。 藉助Firebase,我們可以針對特定的數據引用設置偵聽器,併在每次更新數據時收到通知。 在下麵的示例中,每次為給定用戶更新高分時,它都會將其列印到控制台。

setupHighscoreListener(userId) {
  firebase.database().ref('users/' + userId).on('value', (snapshot) => {
    const highscore = snapshot.val().highscore;
    console.log("New high score: " + highscore);
  });
}

用戶認證

這非常簡單,而且Firebase JavaScript SDK提供的功能相當不錯。但有一點需要註意。我們在開始時簡化了驗證規則。 Firebase SDK為開發人員提供了身份驗證方法,因此他們不必重新實現通用登錄系統,例如Google或Facebook登錄。

這包括Firebase的Web,Android和iOS SDK版本中的UI元素,但是,這些UI組件不適用於React Native,因此不應調用。值得慶幸的是,由於我們自己提供用戶身份驗證,Firebase為我們提供了驗證數據訪問的方法。

登錄方法

我們可以選擇對我們的應用程式有意義的不同登錄方法。登錄方法選擇與Firebase資料庫訪問許可權正交,但是,我們需要讓Firebase知道我們如何設置我們的登錄系統,以便它可以正確分配與我們的用戶帳戶匹配的身份驗證令牌以進行數據訪問控制。你可以使用任何你想要的東西,推出你自己的定製登錄系統,或者如果你的所有用戶都可以不受限制的訪問,甚至可以放棄它。

Facebook登入

許多開發人員選擇的通用登錄系統是用戶已熟悉的簡單Facebook登錄。expo已經提供了一個偉大的Facebook登錄組件,所以我們只需要插入即可。

有關如何設置這些信息,請參閱我們文檔的Facebook部分。這與Google和其他人一樣合適。

將登錄提供商與Firebase綁定

一旦您將Facebook登錄添加到您的expo用程式中,我們需要調整Firebase控制台進行檢查。在登錄方法選項卡中的控制台的身份驗證部分下,啟用Facebook作為登錄提供程式。

{
  "rules": {
    "users": {
      "$uid": {
        ".read": true,
        ".write": "$uid === auth.uid"
      }
    }
  }
}

監聽身份驗證
我們現在準備將Facebook登錄代碼與我們的Firebase資料庫實現連接起來。

firebase.initializeApp(config);

// Listen for authentication state to change.
firebase.auth().onAuthStateChanged((user) => {
  if (user != null) {
    console.log("We are authenticated now!");
  }

  // Do other things
});

async function loginWithFacebook() {
  const { type, token } = await Expo.Facebook.logInWithReadPermissionsAsync(
    '<APP_ID>',
    { permissions: ['public_profile'] }
  );

  if (type === 'success') {
    // Build Firebase credential with the Facebook access token.
    const credential = firebase.auth.FacebookAuthProvider.credential(token);

    // Sign in with credential from the Facebook user.
    firebase.auth().signInWithCredential(credential).catch((error) => {
      // Handle Errors here.
    });
  }
}

Facebook登錄方法與您在Facebook登錄指南中看到的方法類似,但是,我們從成功登錄中收到的令牌可以傳遞給Firebase SDK,以通過firebase.auth.FacebookAuthProvider.credential向我們提供Firebase憑據。 然後,我們可以通過firebase.auth()。signInWithCredential使用此憑據進行登錄。

firebase.auth()。onAuthStateChanged事件允許我們在認證狀態發生變化時設置監聽器,因此在我們的情況下,當使用Facebook憑證成功登錄Firebase時,我們會得到一個可以使用的用戶對象 用於驗證數據訪問。

經過身份驗證的數據更新

既然我們有一個用於我們認證用戶的用戶對象,我們可以調整我們以前的storeHighScore()方法來使用用戶對象的uid作為我們的用戶參考。 由於user.uid是由Firebase自動為經過身份驗證的用戶生成的,因此這是引用用戶存儲區的好方法。

function storeHighScore(user, score) {
  if (user != null) {
    firebase.database().ref('users/' + user.uid).set({
      highscore: score
    });
  }
}

下一張繼續介紹,這一篇主要介紹了:expo結合firebase 一個nosql資料庫(本章令我驚訝但又失望!), 歡迎大家關註我的微信公眾號,這篇文章是否被大家認可,我的衡量標準就是公眾號粉絲增長人數。歡迎大家轉載,但必須保留本人博客鏈接!

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 例如:某個表中,插入了兩條除id外其他欄位都一樣的數據,但是查詢的時候只想查到一條。 ...
  • USE 資料庫名稱1;DROP PROCEDURE IF EXISTS 資料庫名稱1.存儲過程名稱;delimiter $$CREATE PROCEDURE 資料庫名稱1.存儲過程名稱(in v_count bigint,in v_count2 bigint)BEGINset @vCount1=v_ ...
  • MySQL管理表和索引 創建表: 1、直接定義一張空表; 2、從其它表中查詢出數據,並以之創建新表; 3、以其它表為模板創建一個空表; 創建表時定義其中的欄位類型時為數值時 加 unisined表示無符號數值類型(只有正數)。 例如create table 表名 ( id int unisgned  ...
  • [root@VM_0_7_centos data]# vim /etc/my.cnf [root@VM_0_7_centos data]# vim /etc/my.cnf [root@VM_0_7_centos data]# /etc/init.d/mysqld restart Shutting d... ...
  • 1.啟動mysql時,一直不成功,查看錯誤日誌 /var/log/mysql/error.log 2.主要的錯誤信息有如下幾條: 3.查詢後是因為記憶體不足,查看記憶體 增加swap交換空間解決問題: 4.增加自動掛載: 在文件/etc/fstab中加入 /swapfile swap swap defa ...
  • ...
  • 前言 今天筆者要介紹的是hive相關的內容,會從概念到安裝,然後之後再一步一步深入介紹相關知識。 一、hive的相關介紹 1.1hive的相關定義 hive是基於Hadoop的一個數據倉庫工具,可以將結構化的數據文件映射為一張資料庫表,並提供簡單的sql查詢功能,可以將sql語句轉換為MapRedu ...
  • Android P開始逐步限制特定非 SDK 介面的訪問許可權,並要求開發者使用公開 API 里的替代介面。針對該特性,更新了Android遠程桌面助手,目前支持Android P開發者預覽版。 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...