我已经设置了基本的FirebaseDatabase
代码,应用程序运行良好,没有任何错误消息,但根据console.log
编译器不会进入实际的Firebase
代码,因为console log
TAG 无法在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()
函数中。就是这样!现在得到了数据:)