从 Firebase 数据库读取不起作用,但没有错误消息 (Kotlin)



我已经设置了基本的FirebaseDatabase代码,应用程序运行良好,没有任何错误消息,但根据console.log编译器不会进入实际的Firebase代码,因为console logTAG 无法在logcat中找到。不知道如何解决此问题,因为没有错误消息。这是基本代码:

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
}

关于如何进行的想法不胜感激。就像我说的,如果需要,我会发布日志:)

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

最新更新