我是android的新手,我能够在kotlin中为我的应用设置firebase。如果我在 Nexus 5X API 27 模拟器中运行应用程序,我可以获取数据库,但是当我在实际设备中运行应用程序时 SAMSUNG S5 (Google Play Services V 12.5.29,android V 5.0)我没有得到 addValueEventListener 回拨。
ref = FirebaseDatabase.getInstance().reference
ref!!.addValueEventListener(object : ValueEventListener {
override fun onCancelled(p0: DatabaseError?) {
Log.d("firebase", "cancelled")
}
override fun onDataChange(p0: DataSnapshot?) {
if (p0!!.exists()){
Log.d("firebase", "date = $p0")
} else {
Log.d("firebase", "no data")
}
}
})
Gradle文件:
apply plugin: 'com.android.application'
apply plugin: 'kotlin-android'
apply plugin: 'kotlin-android-extensions'
android {
compileSdkVersion 26
defaultConfig {
applicationId "com.example.wonder"
minSdkVersion 21
targetSdkVersion 21
versionCode 1
versionName "1.0"
multiDexEnabled true
testInstrumentationRunner
"android.support.test.runner.AndroidJUnitRunner"
}
buildTypes {
release {
minifyEnabled false
proguardFiles getDefaultProguardFile('proguard-android.txt'),
'proguard-rules.pro'
}
}
}
dependencies {
implementation fileTree(dir: 'libs', include: ['*.jar'])
implementation "org.jetbrains.kotlin:kotlin-stdlib-jre7:$kotlin_version"
implementation 'com.android.support:appcompat-v7:26.1.0'
implementation 'com.android.support:support-v4:26.1.0'
implementation 'com.android.support:design:26.1.0'
implementation 'com.android.support.constraint:constraint-layout:1.0.2'
implementation 'com.google.firebase:firebase-messaging:11.2.2'
implementation 'com.google.firebase:firebase-database:11.2.2'
testImplementation 'junit:junit:4.12'
androidTestImplementation 'com.android.support.test:runner:1.0.1'
androidTestImplementation 'com.android.support.test.espresso:espresso-
core:3.0.1'
//implementation 'com.google.android.gms:play-services-maps:11.2.2'
implementation 'com.android.support:recyclerview-v7:26.1.0'
implementation 'com.google.firebase:firebase-core:11.2.2'
// implementation 'com.google.android.gms:play-services-ads:12.0.0'
}
apply plugin: 'com.google.gms.google-services'
我知道它不是数据库规则问题,因为它们已设置为公开。
如果您有任何建议,请告诉我。
由于
编辑:我确实在清单文件中添加了权限
更新:看起来它正在为设备工作,我只需要等待30分钟。我离开了设备并在一段时间后回来了,数据就在那里。这可能是线程问题吗?我没有做任何线程,因为Firebase自己处理它。
答案 0 :(得分:3)
在您的Manifest文件中确保您拥有的应用程序(主清单文件):
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE"/>
<uses-permission android:name="android.permission.INTERNET"/>
答案 1 :(得分:1)
如果您在设备上使用发布版本,可能会发生这种情况。确保已在firebase应用程序控制台中添加了版本sha1。
单击添加指纹以输入发布sha1。
在您的模拟器中,它可能正常工作,因为您已在firebase应用程序密钥中添加了调试sha1和软件包名称。
答案 2 :(得分:0)
您的应用可能与该设备不兼容。检查您支持的最低版本和设置,以使您的应用也与此设备兼容。
(或)
检查回调:
通过调用Firebase数据库引用上的removeEventListener()方法来删除回调。
“如果已将监听器多次添加到数据位置,则会为每个事件多次调用该监听器,并且必须将其分离相同的次数才能完全删除它。 在父侦听器上调用removeEventListener()不会自动删除在其子节点上注册的侦听器;还必须在任何子侦听器上调用removeEventListener()以删除回调。“
(或)
如果您在班级名称或某个文件名中有一些特殊字符,请重命名,因为某些设备会使无效字符变灰。
答案 3 :(得分:0)
尝试调用,FirebaseDatabase.getInstance()。setPersistenceEnabled(true);在你的应用程序类中&#34; onCreate&#34;方法
我认为您的问题可能就是连接。启用持久性侦听器回调将继续触发本地更新
您可以详细了解here。
答案 4 :(得分:0)
我有类似的问题,这使我发疯。 该应用程序运行良好,突然我停止从Firestore中获取数据,但是当我添加了网络状态权限后,它就可以正常工作
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE"/>
不知道原因,但是此权限救了我。
答案 5 :(得分:0)
就我而言,我只需要重置WiFi路由器即可。我不明白为什么会这样,但是它起作用了,这个答案对我有帮助:Firebase database listeners don't work on android with wifi