目次
概要
React NativeプロジェクトでFirebaseを使うためreact-native-firebase
をインストールする方法について説明します。
- react-native-firebase(V6): https://rnfirebase.io/
react-native-firebaseの以前のバージョン(V5)を使う方法については下記のブログリストを参考してください。
このブログポストはシリーズで作成されております。他の内容を確認したい方は下記のブログリストを参考してください。
- react-native-firebase V6 インストール
- react-native-firebase V6 Crashlytics
- react-native-firebase V6 Admob
ライブラリインストール
下記のコマンドを使ってreact-native-firebase
をインストールします。
npm install --save @react-native-firebase/app
下記のコマンドを使ってiOSプロジェクトへreact-native-firebaseを連結します。
cd ios
pod install
Firebaseプロジェクト生成
次はグーグルファイアベース(Google Firebase)でプロジェクトを生成する必要があります。下記のリンクを押してグーグルファイアベース(Google Firebase)へ移動します。
- グーグルファイアベース(Google Firebase): https://firebase.google.com
data:image/s3,"s3://crabby-images/175b4/175b4af646aa6cf677f8029b97df3b72b7a43bb4" alt="google firebase"
右上のSIGN IN
ボタンを押してログインします。
data:image/s3,"s3://crabby-images/83845/8384569eb05bc9ca38daae4fe93526eeee571c5a" alt="google firebase after login"
ログインしたら、右上のGO TO CONSOLE
ボタンを押してグーグルファイアベースコンソール(Google Firebase Console)へ移動します。
data:image/s3,"s3://crabby-images/5c624/5c6248c34f1961584725ca44d09ed0646706c98d" alt="google firebase console"
グーグルファイアベースコンソール(Google Firebase Console)で+ Add project
を押してプロジェクトを追加します。
data:image/s3,"s3://crabby-images/dd0ec/dd0ece79271e24d66333eed28b32b8dc8785daf9" alt="google firebase console add project"
上のような画面でEnter your project name
へ作りたいFirebaseプロジェクトの名前を入力します。入力が終わったら、下記にあるContinue
ボタンを押して次へ進めます。
data:image/s3,"s3://crabby-images/fc24c/fc24c04f77d6f6b5ee5c106370a2b0895ec69964" alt="google firebase console add google analytics"
プロジェクト名を入力したら、上のようにGoogle Analytics
を連動する画面が表示されます。Google Analyticsと連動したくない場合、左下にあるボタンを押してDisable
で変更してFirebaseプロジェクトを生成します。
Google Analyticsと連動したい方はContinue
を押して進めます。
data:image/s3,"s3://crabby-images/db119/db1193072f3ca62e7cb8fe06dc3a0b25f7d87c79" alt="google firebase console add integrate google analytics"
Google Analyticsのアカウントを選択して、Create project
ボタンを押してFirebaseプロジェクトを生成します。
iOS設定
react-native-firebaseを使うためiOSを設定する方法について説明します。
Bundle ID変更
FirebaseへiOSプロジェクトを生成する前にiOSのBundle ID
を変更する必要があります。ios/[project name].xcworkspace
を選択してXcodeを実行します。
data:image/s3,"s3://crabby-images/de6cc/de6cc4d87a1692fea2cff75288c8940b4bb748ce" alt="change ios bundle id"
左上のプロジェクト名を選択してGeneral
タブへ移動したら、上にBundle Identifier
があることが確認できます。このBundle IDを自分のプロジェクトへ合わせて変更します。
Firebase iOSプロジェクト設定
グーグルファイアベースコンソール(Google Firebase Console)でプロジェクトを選択したら下記のような画面が見えます。
data:image/s3,"s3://crabby-images/40c18/40c1831520c18a3ef850e4fd48c45561405bf2b0" alt="google firebase console project"
真ん中へiOS
ボタンを押してiOSの設定画面へ移動します。
data:image/s3,"s3://crabby-images/673c3/673c34deb64d80e822ba69982f5028584cb99cd9" alt="google firebase console project ios"
開発したアプリのID(bundle ID)を入力してRegister app
ボタンを選択します。
data:image/s3,"s3://crabby-images/65b45/65b45c2e9ec3cc916f6211201b9815c1f659180a" alt="GoogleService-Info.plist download"
グーグルファイアベース(Google Firebase)が生成したGoogleService-Info.plist
ファイルをダウンロードしてinfo.plist
同じ位置へ追加します。GoogleService-Info.plist
ファイルを追加したら、Next
ボタンを押します。
data:image/s3,"s3://crabby-images/e4096/e40963122271c5f3513a3b39a70e789834f3f0c5" alt="add Firebase SDK"
画面へ表示された方法でグーグルファイアベースSDK(Google Firebase SDK)をReact Nativeプロジェクトへ追加する必要があります。./ios/Podfile
ファイルを開いて下記のように修正します。
target 'blaboo' do
...
pod 'Firebase/Analytics'
...
end
Google Analyticsを使ってない方は上のようにコードを修正する必要がないです。
下記のコマンドでグーグルファイアベースSDK(Google Firebase SDK)をインストールします。
pod install
# pod update
data:image/s3,"s3://crabby-images/d98d8/d98d875632bd4625f94a72440a0dcbb5e2884c4b" alt="edit appdelegate.m for firebase"
React NativeプロジェクトのAppDelegate.m
ファイルへ下記のようにコードを追加します。
...
@import Firebase;
@implementation AppDelegate
...
- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions
{
[FIRApp configure];
...
return YES;
}
...
グーグルファイアベースSDK(Google Firebase SDK)を初期化します。
data:image/s3,"s3://crabby-images/707fe/707febe4bc65d2555bc3f66f51daff74742610c1" alt="connect firebase to app"
私はこの部分でSkip this step
を押してスキップしました。
アンドロイド設定
次は、react-native-firebaseを使うためアンドロイドを設定する方法について説明します。
アンドロイドパッケージ名修正
React Nativeプロジェクトフォルダへ
android/app/BUCK
ファイルを修正... android_build_config( ... package = "package_name", ) ... android_resource( ... package = "package_name", ... ) ...
React Nativeプロジェクトフォルダで
android/app/src/main/AndroidManifest.xml
ファイル修正<manifest xmlns:android="http://schemas.android.com/apk/res/android" package="package_name"> ...
React Nativeプロジェクトフォルダで
android/app/src/main/java/com/ProjectName/MainActivity.java
ファイル修正package package_name; ...
React Nativeプロジェクトフォルダで
android/app/src/main/java/com/ProjectName/MainApplication.java
ファイル修正package package_name; ...
React Nativeプロジェクトフォルダで
android/app/build.gradle
ファイル修正... defaultConfig { applicationId package_name ... } ...
このようにパッケージ名を変更したら、android/app/src/main/java/com/[App Name]/MainActivity.java
でできてるフォルダ構造をandroid/app/src/main/java/[Package Name Folder]/MainActivity.java
ように変更する必要があります。
Firebaseアンドロイドプロジェクト設定
グーグルファイアベースコンソール(Google Firebase Console)で左上のProject Overview
を選択します。
data:image/s3,"s3://crabby-images/d79f3/d79f38d3a5dd6d0b7a548db34f3e0a9b896e9873" alt="Google Firebase Console Project Overview"
上にある+ Add app
> アンドロイド(Android)アイコン
を押してアンドロイド(Android)プロジェクトの設定へ移動します。
data:image/s3,"s3://crabby-images/b0c69/b0c698df631317c1001b34054a5c311200e73e5e" alt="Google Firebase Android app register"
アンドロイドパッケージ名(Android Package Name)を入力してRegister app
を選択します。
data:image/s3,"s3://crabby-images/0798c/0798c5e7da18005cf00049426c1ebb3fecef8977" alt="Google Firebase google-services.json setting"
グーグルファイアベース(Google Firebase)が作ったgoogle-services.json
ファイルをReact Nativeプロジェクトのandroid/app
フォルダへコピーします。そしてNext
ボタンを押して次へ進めます。
data:image/s3,"s3://crabby-images/e567e/e567ea3d526ac4c02ba96fcd943587d1dadb10df" alt="Google Firebase setting on android"
React Nativeプロジェクトがあるフォルダへandroid/build.gradle
ファイルを開いて下記のように修正します。
buildscript {
repositories {
google()
jcenter()
}
dependencies {
classpath("com.android.tools.build:gradle:3.5.2")
classpath 'com.google.gms:google-services:4.3.3'
}
}
...
allprojects {
repositories {
mavenLocal()
google()
jcenter()
...
}
}
上のようにrepositories
へgoogle()
が含めてあるか、jcenter()
より上に宣言されたか確認します。
React Nativeプロジェクトがあるフォルダでandroid/app/build.gradle
ファイルを開いて下記のようにコードを追加します。
apply plugin: 'com.android.application'
apply plugin: 'com.google.gms.google-services'
...
dependencies {
implementation platform('com.google.firebase:firebase-bom:26.2.0')
implementation 'com.google.firebase:firebase-analytics'
...
}
...
apply plugin: 'com.google.gms.google-services'
次は./android/build.gradle
ファイルを開いて下記のように修正します。
buildscript {
ext {
...
}
repositories {
...
}
dependencies {
classpath("com.android.tools.build:gradle:3.4.2")
classpath 'com.google.gms:google-services:4.3.3'
}
}
完了
これでReact NativeでFirebaseを使うためreact-native-firebase
をインストールする方法について説明しました。他の機能を追加する方法については下記のリンクを参考してください。
私のブログが役に立ちましたか?下にコメントを残してください。それは私にとって大きな大きな力になります!
アプリ広報
Deku
が開発したアプリを使ってみてください。Deku
が開発したアプリはFlutterで開発されています。興味がある方はアプリをダウンロードしてアプリを使ってくれると本当に助かります。