天天看點

Firebase系列之---Realtime Database(實時資料庫)的使用

我的簡書:簡書

Firebase系列之---Realtime Database(實時資料庫)的使用

1、Firebase系列之—初探Firebase

2、Firebase系列之—Cloud Messaging/Notifications(雲消息,推送)的使用

3、Firebase系列之—Realtime Database(實時資料庫)的使用

Realtime Database

Firebase Realtime Database 是一種雲托管資料庫。資料庫将資料存儲為 JSON,并以實時方式與每個連接配接的用戶端同步。 當您使用我們的 iOS、Android 和 JavaScript SDK 建構跨平台應用時,您的所有用戶端都會分享同一個 Realtime Database 執行個體,并自動接收更新的最新資料。

Firebase Realtime Database存儲資料,并與NoSQL 雲資料庫同步。資料實時跨所有用戶端同步,當您的應用處于離線狀态時仍可使用該資料。

Firebase Realtime Database不是使用通常的 HTTP 請求,而是使用資料同步。每當資料變化時,任何連接配接的裝置都會以毫秒速度收到該更新資料。 提供互相協作、身臨其境的體驗,不用考慮任何網絡代碼。

本文簡單介紹Firebase如何實作簡單資料的實時同步存儲。(更新中…)

1、準備工作和連接配接Firebase

點選檢視Firebase系列之—初探Firebase

2、引用SDK和編寫代碼

  • 1) 引用Firebase Realtime Database SDK

在app的build.gradle檔案中添加:

dependencies {
  compile 'com.google.firebase:firebase-database:9.6.1'
}
           
  • 2) 編寫布局,實作資料實時同步

    activity_database:

<?xml version="1.0" encoding="utf-8"?>
<ScrollView
    xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent">
    <LinearLayout
        android:id="@+id/activity_main"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:orientation="vertical"
        android:paddingBottom="@dimen/activity_vertical_margin"
        android:paddingLeft="@dimen/activity_horizontal_margin"
        android:paddingRight="@dimen/activity_horizontal_margin"
        android:paddingTop="@dimen/activity_vertical_margin"
        tools:context="com.shawpoo.firebase.app.activity.MainActivity">
        <TextView
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="@string/fire_base_data_base"
            android:textSize="16sp"/>
        <!-- 實時資料庫-->
        <LinearLayout
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:orientation="vertical"
            android:padding="@dimen/activity_horizontal_margin">
            <TextView
                android:id="@+id/tv_db_value"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:layout_gravity="center_horizontal"
                android:text="@string/show_default_value"/>
            <EditText
                android:id="@+id/et_value"
                android:layout_width="match_parent"
                android:layout_height="wrap_content"
                android:hint="@string/db_edit_hint"
                android:maxLines="1"
                android:textSize="15sp"/>
            <Button
                android:id="@+id/btn_db_set"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:layout_gravity="center_horizontal"
                android:text="@string/db_set_value"/>
        </LinearLayout>
    </LinearLayout>
</ScrollView>
           
  • 3) 實作邏輯,使用Firebase Realitme Database:

将資料寫入Database中:

FirebaseDatabase database = FirebaseDatabase.getInstance();
DatabaseReference myRef = database.getReference("message");

myRef.setValue("Hello, World!");
           

從Database中讀取資料(添加資料改變的監聽):

myRef.addValueEventListener(new ValueEventListener() {
    @Override
    public void onDataChange(DataSnapshot dataSnapshot) {
        String value = dataSnapshot.getValue(String.class);
        Log.d(TAG, "Value is: " + value);
    }

    @Override
    public void onCancelled(DatabaseError error) {
        Log.w(TAG, "Failed to read value.", error.toException());
    }
});
           

完整的DataBaseActivity代碼:

public class DataBaseActivity extends BaseAppCompatActivity {

    private static final String TAG = "FIRE_BASE";
    //實時資料庫
    private EditText mDbEdit;
    private TextView mShowValueText;
    private Button mDbSetValueBtn;


    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_database);

        initView();
        database();
    }

    /**
     * 初始化各種控件
     */
    private void initView() {
        mDbEdit = (EditText) findViewById(R.id.et_value);
        mShowValueText = (TextView) findViewById(R.id.tv_db_value);
        mDbSetValueBtn = (Button) findViewById(R.id.btn_db_set);
    }

    /**
     * 實時資料庫功能
     */
    private void database() {
        //擷取資料庫執行個體
        FirebaseDatabase database = FirebaseDatabase.getInstance();
        //擷取Reference  "message"為存儲值的key
        final DatabaseReference myRef = database.getReference("message");

        mDbSetValueBtn.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View view) {
                String str = mDbEdit.getText().toString().trim();
                if (TextUtils.isEmpty(str)) {
                    showToast("還沒輸入要存儲的内容嘞");
                    return;
                }
                //為實時資料庫存值
                myRef.setValue(str);
            }
        });
        //注冊當值發生改變時的事件監聽
        myRef.addValueEventListener(new ValueEventListener() {
            @Override
            public void onDataChange(DataSnapshot dataSnapshot) {
                String value = dataSnapshot.getValue(String.class);
                mShowValueText.setText("顯示:" + value);
            }

            @Override
            public void onCancelled(DatabaseError error) {
                showToast("擷取異常");
                Log.e(TAG, error.toException().toString());
            }
        });
    }

}
           
Firebase系列之---Realtime Database(實時資料庫)的使用
  • 3) 修改存儲規則

本文為了測試,暫時将讀寫規則改為任何人都可以讀寫。建議在正式項目要一定要加使用者校驗。

{
  "rules": {
    ".read": true,
    ".write": true  
  }
}
           
Firebase系列之---Realtime Database(實時資料庫)的使用

3、檢視運作結果

通過下面的gif圖可以看出手機和Firebase控制台真正的實作了資料的實時同步。

Firebase系列之---Realtime Database(實時資料庫)的使用
  • 後記: 本文暫時介紹簡單文本的同步存儲,後續将更新儲存對象…敬請期待。