將多個使用者類型重新導向到各自的活動
在Firebase 中,管理不同類型的使用者並適當地重新導向他們對於自訂他們的體驗至關重要。為此,必須考慮資料庫架構和授權偵聽器調整。
資料庫結構注意事項
處理多種使用者類型時,合併使用者類型資訊是有益的進入資料庫。透過為使用者類型建立節點,您將能夠區分它們。例如,您可以有一個「使用者」節點,其中包含每個使用者類型的子節點(例如「學生」、「教師」和「管理員」)。在每個子節點中,包含基本的使用者訊息,例如 UID、名稱和類型。
修改多個使用者的授權偵聽器
設定資料庫結構後,修改授權監聽器來處理多種使用者類型。以下是修改後的程式碼範例:
mAuthListener = new FirebaseAuth.AuthStateListener() { @Override public void onAuthStateChanged(FirebaseAuth firebaseAuth) { FirebaseUser firebaseUser = FirebaseAuth.getInstance().getCurrentUser(); if (mAuth.getCurrentUser() != null) { String uid = mAuth.getInstance().getCurrentUser().getUid(); DatabaseReference rootRef = FirebaseDatabase.getInstance().getReference(); DatabaseReference uidRef = rootRef.child("users").child(uid); ValueEventListener valueEventListener = new ValueEventListener() { @Override public void onDataChange(DataSnapshot dataSnapshot) { if(dataSnapshot.child("Type").getValue(Long.class) == 1) { startActivity(new Intent(MainActivity.this, student.class)); } else if (dataSnapshot.child("TYPE").getValue(Long.class) == 2) { startActivity(new Intent(MainActivity.this, teacher.class)); } else if (dataSnapshot.child("TYPE").getValue(Long.class) == 3) { startActivity(new Intent(MainActivity.this, admin.class)); } } @Override public void onCancelled(@NonNull DatabaseError databaseError) { Log.d(TAG, databaseError.getMessage()); } }; uidRef.addListenerForSingleValueEvent(valueEventListener); } else{ Log.d("TAG", "firebaseUser is null"); } } };
說明:
在此程式碼中,我們造訪Firebase 中的「users」節點並檢查使用者的「 Type」屬性在ValueEventListener 的onDataChange() 方法中。根據類型(1、2 或 3),我們將使用者重新導向到適當的活動(學生、教師或管理員)。
這種修改後的方法提供了一種靈活的解決方案,可以利用資料庫結構和授權偵聽器修改。
以上是如何將不同使用者類型重新導向到 Firebase 中各自的活動?的詳細內容。更多資訊請關注PHP中文網其他相關文章!