1. Übersicht
Willkommen beim Integrieren des Firebase App Distribution SDK in das Codelab Ihrer Android-App. In diesem Codelab fügen Sie das App Distribution Android SDK zu Ihrer App hinzu, um Ihren Testern In-App-Benachrichtigungen anzuzeigen, wenn neue Builds zum Herunterladen verfügbar sind. Sie erfahren, wie Sie sowohl eine Basiskonfiguration als auch eine benutzerdefinierte Konfiguration verwenden, um Ihre Tester zum Empfangen von Updates anzumelden. Dann pushen Sie eine neue Version an die App-Verteilung und lösen direkt in der App eine neue Build-Warnung aus.
Was Sie lernen werden
- So verwenden Sie die App-Verteilung, um eine Vorabversion einer App an Tester zu verteilen
- So integrieren Sie das App Distribution Android SDK in Ihre App
- So benachrichtigen Sie einen Tester, wenn ein neuer Vorabversions-Build zur Installation bereitsteht
- So passen Sie das SDK an Ihre Testanforderungen an
Was du brauchen wirst
- Android Studio-Version 3.4+.
- Beispielcode.
- Ein Testgerät mit Android 2.3+ und Google Play-Diensten 9.8 oder höher oder ein Emulator mit Google Play-Diensten 9.8 oder höher.
- Bei Verwendung eines Geräts ein Verbindungskabel.
Wie werden Sie dieses Tutorial verwenden?
Wie würden Sie Ihre Erfahrung beim Erstellen von Android-Apps bewerten?
2. Holen Sie sich den Beispielcode
Klonen Sie das GitHub-Repository über die Befehlszeile.
$ git clone https://github.com/FirebaseExtended/codelab-appdistribution-android.git
Wenn Sie Git nicht installiert haben, können Sie das Beispielprojekt auch von der GitHub-Seite herunterladen oder auf diesen Link klicken.
3. Importieren Sie die Starter-App
Wählen Sie in Android Studio das Verzeichnis codelab-appdistribution-android/start
( ) aus dem Beispielcode-Download ( Datei > Öffnen > .../codelab-appdistribution-android/start).
Sie sollten nun das Startprojekt in Android Studio geöffnet haben.
4. Erstellen Sie ein Firebase-Konsolenprojekt
Fügen Sie ein neues Firebase-Projekt hinzu
- Öffnen Sie die Firebase-Konsole .
- Wählen Sie Projekt hinzufügen aus und nennen Sie Ihr Projekt dann "Firebase Codelab".
Sie müssen Google Analytics für dieses Projekt nicht aktivieren.
- Klicken Sie auf Projekt erstellen .
Fügen Sie eine App zu Firebase hinzu
Registrieren Sie Ihre App bei Firebase . Verwenden Sie "com.google.firebase.appdistributioncodelab" als Paketnamen.
Fügen Sie Ihrer App die Datei google-services.json hinzu
Nachdem Sie den Paketnamen hinzugefügt und Registrieren ausgewählt haben, führen Sie die folgenden Schritte aus, um google-services.json zu Ihrer App hinzuzufügen:
- Klicken Sie auf Download google-services.json, um Ihre Firebase-Android-Konfigurationsdatei abzurufen.
- Kopieren Sie die Datei google-services.json in das
app
Verzeichnis Ihres Projekts. - Nachdem die Datei heruntergeladen wurde, können Sie die nächsten in der Konsole angezeigten Schritte überspringen (sie wurden bereits im build-android-start-Projekt für Sie erledigt).
Aktualisieren Sie die Anwendungs-ID entsprechend Ihrer Firebase-App
- Stellen Sie im linken Menü (Registerkarte „Projekt“) sicher, dass Sie sich in der „Android“-Ansicht befinden, suchen Sie die Registerkarte „Gradle Scripts“ und öffnen Sie die Gradle-Datei Ihres Moduls (auf App-Ebene) (normalerweise
app/build.gradle
). - Ändern Sie die Eigenschaft
applicationId
so, dass sie mit der Anwendungs-ID Ihrer Firebase-App übereinstimmt. Dies sollte "com.google.firebase.appdistributioncodelab" sein.
Synchronisieren Sie Ihr Projekt mit Gradle-Dateien
Um sicherzustellen, dass alle Abhängigkeiten für Ihre App verfügbar sind, synchronisieren Sie Ihr Projekt mit Gradle-Dateien, indem Sie in der Symbolleiste von Android Studio Datei > Projekt mit Gradle-Dateien synchronisieren auswählen .
5. Richten Sie In-App-Warnungen für neue Builds mit dem App Distribution Android SDK ein
In diesem Schritt fügen Sie Ihrer App das Firebase App Distribution Android SDK hinzu und zeigen Ihren Testern In-App-Benachrichtigungen an, wenn neue Builds Ihrer App zur Installation verfügbar sind. Stellen Sie dazu sicher, dass Sie die Firebase App Testers API für Ihr „Firebase Codelab“-Projekt (in der Google Cloud Console) aktiviert haben. Sie müssen sich mit demselben Konto anmelden und das richtige Projekt aus dem Dropdown-Menü oben auswählen.
Konfigurieren Sie In-App-Warnungen
Das App Distribution Android SDK bietet zwei Möglichkeiten zum Einrichten von In-App-Build-Benachrichtigungen für Ihre Tester:
- Eine grundlegende Benachrichtigungskonfiguration, die mit einem vorgefertigten Dialogfeld zur Anzeige für Tester geliefert wird.
- Eine erweiterte Alarmkonfiguration, mit der Sie Ihre Benutzeroberfläche (UI) anpassen können.
Wir beginnen mit der grundlegenden Alarmkonfiguration. Sie können updateIfNewReleaseAvailable
verwenden, um Testern, die noch keine Warnungen aktiviert haben, ein vorgefertigtes Dialogfeld zum Aktivieren von Warnungen anzuzeigen und dann zu prüfen, ob ein neuer Build verfügbar ist. Tester aktivieren Warnungen, indem sie sich bei einem Konto anmelden, das Zugriff auf die App in App Distribution hat. Beim Aufruf führt die Methode die folgende Sequenz aus:
- Überprüft, ob ein Tester Warnungen aktiviert hat. Wenn nicht, zeigt die Methode ein vorgefertigtes Dialogfeld an, das die Tester auffordert, sich mit ihrem Google-Konto bei App Distribution anzumelden.
Das Aktivieren von Warnungen ist ein einmaliger Vorgang auf dem Testgerät, der über Updates Ihrer App hinweg bestehen bleibt. Warnungen bleiben auf dem Testgerät aktiviert, bis die App deinstalliert oder die signOutTester
Methode aufgerufen wird.
- Sucht nach neu verfügbaren Builds, die der Tester installieren kann.
- Zeigt eine vorgefertigte Warnung an, die den Tester auffordert, die neueste Version herunterzuladen.
- Überprüft den neuen Build-Typ, bevor mit dem Update fortgefahren wird:
- Wenn es sich bei dem neuen Build um ein App Bundle (AAB) handelt, wird der Tester zum Play Store umgeleitet, um den Aktualisierungsvorgang abzuschließen.
- Wenn der neue Build ein APK ist, lädt das SDK den neuen Build im Hintergrund herunter und fordert den Tester auf, den neuen Build zu installieren, wenn der Download abgeschlossen ist. Das SDK sendet mithilfe von
NotificationManager.
Sie können Ihre eigene Fortschrittsanzeige hinzufügen, indem Sie einenonProgressUpdate
Handler an dieupdateIfNewReleaseAvailable
-Aufgabe anfügen.
Sie können updateIfNewReleaseAvailable()
an jeder Stelle in Ihrer App aufrufen. Beispielsweise können Sie updateIfNewReleaseAvailable()
während der Methode onResume()
der MainActivity aufrufen:
Öffnen Sie MainActivity.kt und erstellen Sie die Methode onResume()
wie folgt:
MainActivity.kt
override fun onResume() {
super.onResume()
checkForUpdate()
}
Lassen Sie uns nun die Methode checkForUpdate()
implementieren.
MainActivity.kt
private fun checkForUpdate() {
firebaseAppDistribution.updateIfNewReleaseAvailable()
.addOnProgressListener { updateProgress ->
// (Optional) Implement custom progress updates in addition to
// automatic NotificationManager updates.
}
.addOnFailureListener { e ->
if (e is FirebaseAppDistributionException) {
// Handle exception.
}
}
}
6. Erstellen Sie Tester und laden Sie sie ein, Ihre App herunterzuladen
In diesem Schritt erstellen Sie Ihre App und testen Ihre Implementierung, indem Sie den Build mithilfe der Firebase-Konsole an Tester verteilen .
Erstellen Sie Ihre Anwendung
Wenn Sie bereit sind, eine Vorabversion Ihrer App an Tester zu verteilen, erstellen Sie Ihr APK mit Ihrem normalen Prozess. Sie müssen das APK mit Ihrem Debug-Schlüssel oder App-Signaturschlüssel signieren.
Verteilen Sie Ihre App an Tester
Um Ihre App an Tester zu verteilen, laden Sie die APK-Datei über die Firebase-Konsole hoch:
- Öffnen Sie die Seite „App-Verteilung“ der Firebase-Konsole. Wählen Sie Ihr Firebase-Projekt aus, wenn Sie dazu aufgefordert werden.
- Wählen Sie auf der Seite Releases die App, die Sie verteilen möchten, aus dem Dropdown-Menü aus.
- Klicken Sie auf Erste Schritte
- Ziehen Sie die APK-Datei Ihrer App auf die Konsole, um sie hochzuladen.
- Geben Sie nach Abschluss des Uploads die Testergruppen und einzelnen Tester an, die den Build erhalten sollen. (Fügen Sie Ihre E-Mail-Adresse hinzu, um die Einladung zu erhalten.) Fügen Sie dann Versionshinweise für den Build hinzu. Weitere Informationen zum Erstellen von Testergruppen finden Sie unter Tester hinzufügen und entfernen .
- Klicken Sie auf Verteilen, um den Build Testern zur Verfügung zu stellen.
In der Firebase-Konsole können Sie jetzt die Tester sehen, die Sie unter der Version Ihrer App hinzugefügt haben.
Da Sie Ihre E-Mail-Adresse angegeben haben, erhalten Sie eine E-Mail von Firebase App Distribution, in der Sie zum Testen der App eingeladen werden. Sie sind jetzt der erste Tester! Befolgen Sie die Anweisungen unter Akzeptieren Sie die Einladung, um sich als Tester auf Ihrem Testgerät einzurichten.
Die Einladung akzeptieren
Sie müssen zuerst die Einladung annehmen, um die Version herunterzuladen und zu testen.
- Öffnen Sie auf Ihrem Android-Testgerät die von Firebase App Distribution gesendete E-Mail und tippen Sie auf Erste Schritte .
- Melden Sie sich in der angezeigten Firebase App Distribution Tester-Web-App mit Ihrem Google-Konto an und tippen Sie auf Einladung annehmen. Sie können jetzt die Version sehen, zu der Sie eingeladen wurden.
Laden Sie die Version vom Testgerät herunter
Wenn Sie zur Codelab-App AppDistribution navigieren, können Sie sehen, dass die Version zum Herunterladen bereit ist.
- Tippen Sie auf Download , installieren Sie die App und führen Sie sie aus!
- Wenn die App startet, werden Sie aufgefordert, neue Build-Warnungen zu aktivieren. Tippen Sie auf Einschalten .
- Melden Sie sich mit Ihrem Tester-Konto an.
Sie kehren zur App zurück. Wenn Sie die App das nächste Mal ausführen, müssen Sie sich nicht anmelden oder Benachrichtigungen akzeptieren
Verteilen Sie ein Update an Ihre Tester
- Aktualisieren Sie Ihren Versionsnamen auf „1.1“ und Ihren Versionscode auf 2 in der Gradle-Datei Ihres Moduls (auf App-Ebene) (normalerweise app/build.gradle).
- Erstellen Sie Ihr APK mit Ihrem normalen Prozess. Sie müssen das APK mit Ihrem Debug-Schlüssel oder App-Signaturschlüssel signieren.
- Laden Sie dieses neue APK in Ihre Firebase-Konsole hoch, fügen Sie Ihre E-Mail-Adresse erneut als Tester hinzu und klicken Sie auf Verteilen .
Benachrichtigungen zum Testen von Builds
- Stellen Sie sicher, dass Sie die App geschlossen haben, falls sie geöffnet war.
- Starten Sie die Anwendung neu.
- Wenn die App neu gestartet wird, erhalten Sie eine Benachrichtigung „Neue Version verfügbar“.
- Um die neueste Version zu erhalten, klicken Sie auf Aktualisieren .
- Wenn Sie dazu aufgefordert werden, wählen Sie die Option zum Aktivieren von Installationen aus unbekannten Quellen.
- Klicken Sie im nächsten Bildschirm auf Installieren (oder Aktualisieren ).
- Glückwunsch! Sie konnten Ihre App mit den integrierten Benachrichtigungen aktualisieren.
7. Passen Sie die Tester-Anmeldung an
Die Methoden signInTester/signOutTester und isTesterSignedIn bieten Ihnen mehr Flexibilität beim Anpassen der Anmeldeerfahrung Ihres Testers, damit sie besser zum Erscheinungsbild Ihrer App passt.
Im folgenden Beispiel wird überprüft, ob sich der Tester bereits bei seinem Firebase App Distribution-Testerkonto angemeldet hat, sodass Sie Ihre Anmeldebenutzeroberfläche nur für Tester anzeigen können, die sich noch nicht angemeldet haben. Nachdem sich der Tester angemeldet hat, können Sie dies tun Rufen Sie checkForUpdate auf, um zu prüfen, ob der Tester Zugriff auf einen neuen Build hat.
Deaktivieren wir die automatische Überprüfung von Updates in onResume , indem wir den Aufruf checkForUpdate() auskommentieren.
MainActivity.kt
override fun onResume() {
super.onResume()
//checkForupdate()
}
Stattdessen ist checkForUpdate() bereits im OnClickListener von updatebutton hinzugefügt.
Lassen Sie uns nun unsere Methode signIn() implementieren, die den Benutzer anmeldet, wenn er abgemeldet ist, oder den Benutzer abmeldet, wenn er bereits angemeldet ist.
MainActivity.kt
private fun signIn() {
if (isTesterSignedIn()) {
firebaseAppDistribution.signOutTester()
configureUpdateButton()
configureSigninButton()
} else {
firebaseAppDistribution.signInTester()
}
}
Schließlich implementieren wir die isTesterSignedIn -Methode.
MainActivity.kt
private fun isTesterSignedIn() : Boolean {
return firebaseAppDistribution.isTesterSignedIn
}
Erstellen und testen Sie Ihre Implementierung
8. Herzlichen Glückwunsch!
Sie haben die Funktion „In-App-Benachrichtigungsanzeige“ mithilfe des Firebase App Distribution Android SDK in eine App integriert.
Was wir abgedeckt haben
- Firebase-App-Verteilung
- Firebase App Distribution Neue Benachrichtigungen Android SDK
Nächste Schritte
Erfahren Sie mehr
Eine Frage haben?
Probleme melden