【问题标题】:Firebase Database does not work on android emulatorFirebase 数据库在 android 模拟器上不起作用
【发布时间】:2020-08-02 12:31:47
【问题描述】:

我的应用正在检查某个数据是否在 Firebase 实时数据库中,并将 addListenerForSingleValueEvent 添加到数据库引用中。我开始该项目的模拟器工作正常并且可以完美地检索数据,但是当我更改模拟器(假设我切换到 PIXEL 3XL)时,监听器不起作用。我在另一个 stackoverflow 问题中看到有人遇到了同样的问题,并且数据库检索了数据,但经过了很长时间。有谁知道为什么会这样?我是否应该继续使用默认模拟器进行开发而不关心实时数据库无法在另一个模拟器上运行?你能解释一下为什么会这样吗?

我在清单中使用它: ...<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE"/>...

分级

buildscript {
    repositories {
        google()
        jcenter()
    }
    dependencies {
        classpath "com.android.tools.build:gradle:4.0.1"
        classpath 'com.google.gms:google-services:4.3.3'

        // NOTE: Do not place your application dependencies here; they belong
        // in the individual module build.gradle files
    }
}

allprojects {
    repositories {
        google()
        jcenter()
    }
}

task clean(type: Delete) {
    delete rootProject.buildDir
}

gradle(模块)

apply plugin: 'com.google.gms.google-services'

android {
    compileSdkVersion 30
    buildToolsVersion "30.0.1"

    defaultConfig {
        applicationId "..."
        minSdkVersion 28
        targetSdkVersion 30
        versionCode 1
        versionName "1.0"

        testInstrumentationRunner "androidx.test.runner.AndroidJUnitRunner"
    }

    buildTypes {
        release {
            minifyEnabled false
            proguardFiles getDefaultProguardFile('proguard-android-optimize.txt'), 'proguard-rules.pro'
        }
    }
}

dependencies {
    implementation fileTree(dir: "libs", include: ["*.jar"])
    implementation 'androidx.appcompat:appcompat:1.1.0'
    implementation 'androidx.constraintlayout:constraintlayout:1.1.3'
    implementation 'com.google.firebase:firebase-database:19.3.1'
    testImplementation 'junit:junit:4.12'
    androidTestImplementation 'androidx.test.ext:junit:1.1.1'
    androidTestImplementation 'androidx.test.espresso:espresso-core:3.2.0'

}

编辑 1: 添加了代码(它适用于默认模拟器,像素 3,但不适用于另一个)日志只是为了查看代码是否在做它应该做的事情。

DatabaseReference database, newRef;

 protected void onCreate(Bundle savedInstanceState) {
(...)
database = FirebaseDatabase.getInstance().getReference();
newRef = database.child(option).child(strSelectedYear).child(strSelectedMonth).child(strSelectedDay);
        newRef.addListenerForSingleValueEvent(new ValueEventListener() {
            @Override
            public void onDataChange(@NonNull DataSnapshot dataSnapshot) {
                for (DataSnapshot d: dataSnapshot.getChildren()) {
                    hours.remove(d.getKey());
                    Log.i("hAI FRAAA", d.getKey());

                }
                String msg = "";
                for (int j = 0;j<hours.size();j+=1)
                    msg += " " + hours.get(j);
                Log.i("Free hours", msg);
            }

            @Override
            public void onCancelled(@NonNull DatabaseError databaseError) {

            }
        });
}

【问题讨论】:

  • @a_local_nobody 刚刚添加了代码。
  • 可能是因为您使用的是免费版本的 Firebase?它有时会停止工作;)
  • @LeoLeontev :) 我真的不这么认为,因为它总是在默认模拟器上工作。
  • 其他模拟器用的android sdk是什么?
  • @PeterHaddad 我对此很陌生。我希望sdk和模拟器的API版本是一样的。两者(一个工作的和一个不工作的)都是 29

标签: android firebase firebase-realtime-database


【解决方案1】:

您需要自行进行更多故障排除才能找出问题所在。我将采取的几个步骤:

  1. 停止忽略可能的错误并实施onCancelled。至少应该是public void onCancelled(@NonNull DatabaseError databaseError) { throw databaseError.toException(); }
  2. 确保互联网访问在第二个模拟器上正常工作。那么其他应用也能用吗?
  3. Enabling debug logging 并检查 logcat 输出发生了什么。

【讨论】:

  • 感谢您的回答,但不幸的是它仍然无法正常工作。我已经实现了 onCancelled 并确保模拟器可以访问互联网。问题是,我认为监听器被触发了,但是这个模拟器需要很长时间才能获取数据,就像发布这个的人一样:link。我也尝试过人们在那里给出的答案,但我真的卡住了。
  • 您是否也启用了调试日志记录并检查时间的去向,正如我在第 3 步中所说的那样?
  • 我进行了日志调试,应用程序现在正在运行。该问题是由 memtrack 错误引起的,因此我不得不从模拟器中卸载该应用程序并重新安装。我觉得很愚蠢,花了大约 3 个小时在这件事上工作,但至少它正在工作。非常感谢!
猜你喜欢
  • 2020-10-11
  • 2017-09-19
  • 1970-01-01
  • 1970-01-01
  • 2016-06-29
  • 1970-01-01
  • 1970-01-01
  • 2017-03-03
  • 2021-01-07
相关资源
最近更新 更多