首页 > 解决方案 > 从 Firebase 数据库读取不起作用,但没有错误消息 (Kotlin)

问题描述

我已经设置了基本FirebaseDatabase代码,应用程序运行良好,没有任何错误消息,但根据console.log编译器没有进入实际Firebase代码,因为console loglogcat. 由于没有错误消息,因此不确定如何解决此问题。这是基本代码:

import android.support.v7.app.AppCompatActivity
import android.os.Bundle
import android.util.Log
//import com.google.firebase.FirebaseError
import com.google.firebase.database.*
//import com.google.firebase.auth.FirebaseAuth

class RecipeGridView : AppCompatActivity() {

   private var db: DatabaseReference? = null
   private var fbdb: FirebaseDatabase? = null
   private var ref: DatabaseReference? = null

   override fun onCreate(savedInstanceState: Bundle?) {
       super.onCreate(savedInstanceState)
       setContentView(R.layout.activity_recipe_grid_view)
       Log.d("TAG", "ON CREATE");

       fbdb = FirebaseDatabase.getInstance()
       ref = fbdb!!.getReference("cookies")

       ref!!.addChildEventListener(object: ChildEventListener {
           override fun onChildChanged(snapshot: DataSnapshot?, p1: String?) {
            var myDataSnapshot = snapshot!!.getValue()

            Log.d("TAG", "THIS DOESN'T SHOW IN LOGCAT!!!");

            /*for later...
            val children = snapshot!!.children

            print(snapshot.children.count().toString())
            print(p1)

            children.forEach{
                print(it.toString())
            }
    */
        }

        override fun onChildMoved(p0: DataSnapshot?, p1: String?) {}

        override fun onChildRemoved(p0: DataSnapshot?) {}

        override fun onCancelled(error: DatabaseError) {
            print(error)
            Log.d("TAG", "ON ERROR");

        }

        override fun onChildAdded(p0: DataSnapshot?, p1: String?) {}

        }) //END FB CODE
}
}

我很乐意发布日志,但它真的很长并且没有显示任何错误。

依赖项是:

implementation 'com.google.firebase:firebase-database:10.0.1'
implementation 'com.google.firebase:firebase-core:10.0.1'

此外,maven 代码包含在 gradle 中:

maven {
        url "https://maven.google.com" // Google's Maven repository
    }

对如何进行的想法表示赞赏。就像我说的,如果需要,我会发布日志:)

标签: android-studiofirebase-realtime-databasekotlin

解决方案


好的,现在明白了。代码应该在onChildAdded()而不是onChildChange()函数中。就是这样!现在得到数据:)


推荐阅读