Я новичок в Android, и я смог настроить FireBase для моего приложения в Kotlin. Если я запускаю приложение в эмуляторе 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, обрабатывает это сам.