Firebase 数据库无法在 Android 模拟器上运行

问题描述 投票:0回答:5

我的应用程序正在检查 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: 添加了代码(它适用于默认模拟器,pixel 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) {

            }
        });
}
android firebase firebase-realtime-database
5个回答
2
投票

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

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

0
投票

我已经处理这个问题几天了。最后将我的物理 Android 设备连接到计算机解决了我的问题。我猜想模拟器的互联网连接并不像 Firestore 预期的那么健康。问题的原因是我的模拟器。


0
投票

我在最新的 Android 模拟器版本中遇到了同样的问题,我只是替换为预览版本并解决了我的问题。

  1. 前往Android SDK
  2. 复制模拟器
  3. 模拟器下载档案
  4. 下载 Android 模拟器的预览版本
  5. 复制 Android SDK 中的 Emulator 文件夹
  6. 从旧模拟器复制 package.json 并将版本替换为新版本:
    <revision><major>31</major><minor>1</minor><micro>4</micro></revision>
    就是这样。

0
投票

我也有同样的问题。就我而言,使用 Firebase Remote Config 和 Crashlytics。 FirebaseApp 初始化后,模拟器将停止。 (API 28,像素 2)。

在物理设备上,它会按预期继续。

就在我编写时,模拟器继续并初始化了 Firebase 服务。花了 7 分钟和多次尝试(我这边没有任何交互)。

查看日志:


0
投票

可以使用模拟器,只需确保设备(模拟器)上没有连接Wi-Fi即可。

© www.soinside.com 2019 - 2024. All rights reserved.