今回はFlutterプロジェクト用にFirebaseのプロジェクトを作成し、iOS/Androidの設定を行う手順を紹介します。
Firebaseプロジェクトの作成
- Firebase consoleを開きます
Sign in - Google Accounts
- プロジェクトを追加をクリックします。
data:image/s3,"s3://crabby-images/74c8d/74c8d745b5aeb459c4a88d615aa3004910fa5606" alt=""
- プロジェクトの名前を入力します。私はtodoapp-sample-riverpodとしました。
data:image/s3,"s3://crabby-images/a7b6f/a7b6ff40b7ef9bb7ed5c8eb3b77b16d8c02bb286" alt=""
- Google Analyticsを使用するかどうか聞かれるので、お好きに設定頂いて、続行をクリックします。私は有効にしました。
data:image/s3,"s3://crabby-images/0a2f2/0a2f21315ddea386565c1a565358497355e0a523" alt=""
- Google Analyticsを有効にした場合は、アカウントを聞かれるので選択し、「プロジェクトを作成」をクリックします。
data:image/s3,"s3://crabby-images/53f46/53f468e279fe8a1df18ffb1fc6950bd057cee114" alt=""
- プロジェクトが作成されます。このまましばらく待ちます。
data:image/s3,"s3://crabby-images/c8ffc/c8ffc9ce0629781850015a54985c41434b5848e1" alt=""
- 「新しいプロジェクトの準備ができました」と表示されたらプロジェクトの作成が完了です。「続行」をクリックして設定を続けます。
data:image/s3,"s3://crabby-images/340cc/340cc1c598bb9248505f25fd741f47db2fea7350" alt=""
- アプリを追加する前に、Firebaseを使う際に必ず行う必要がある設定を先に行っておきます。こちらのコンソール画面から、左メニューにある「Firestore Database」をクリックします。
data:image/s3,"s3://crabby-images/26258/262589e1c64cae643c889e5aee8e7ce5f4a710c9" alt=""
- データベースの作成をクリックします。
data:image/s3,"s3://crabby-images/4c77a/4c77a28e82c7331a910ab51ad92f7a0598b181d7" alt=""
- 本番環境用に、はじめからセキュリティルールを記載しながら開発をすすめる方以外は、「テストモードで開始する」にチェックを入れて「次へ」をクリックします。
data:image/s3,"s3://crabby-images/05995/05995616a5c2d41b312c9b94641ffb8b0ddcd8c7" alt=""
- Cloud Firestoreのロケーションを選択します。お好きな場所を選べば良いですが、日本であれば「asia-northeast1」を選んでおけば良いかと思います。
data:image/s3,"s3://crabby-images/3ed9e/3ed9ef433ca28da1ef08a4e92c34c0aeee6ee387" alt=""
- Cloud Firestoreの画面が表示されたら設定完了ですので、コンソールに戻ります。
data:image/s3,"s3://crabby-images/8c2db/8c2db30e0caae762c4207f449e5d1e10e1557aad" alt=""
iOSアプリの追加
- 次にiOSアプリを追加します。コンソールのホーム画面の上部にある「開始するにはアプリを追加してください」の上の「iOS+」アイコンをクリックします。
data:image/s3,"s3://crabby-images/7a05e/7a05e6a2b216aa468cce99237d44ab9783918d9d" alt=""
- ここでAndroid Studioのターミナルで
open ios
と打ってiosフォルダを開いたあと、「Runner.xcworkspace」の方をクリックします。(xcodeprojの方ではないです。)
data:image/s3,"s3://crabby-images/2e8b7/2e8b736bd2a60db5d238e569ba0eba48d2e3a6ac" alt=""
- XCodeが開くまで待ち、開いたら左メニューでRunnerを選択し、真ん中でGeneralタブを開くと「Bundle Identifier」が表示されるのでこれをコピーします。
data:image/s3,"s3://crabby-images/20e88/20e8847e6fff91c6ac08634e697904dddd1352ff" alt=""
- Firebaseのコンソールに戻り、アプリの登録画面でAppleバンドルIDに今コピーしたBundle Identifierを貼り付けます。アプリのニックネームはわかりやすいように適宜つけておきます。
data:image/s3,"s3://crabby-images/b983f/b983fa31fedcf196751bdc5a89257113fc2b9699" alt=""
- 設定ファイルのダウンロード画面で、「GoogleService-Info.plist」をダウンロードします。
data:image/s3,"s3://crabby-images/aba17/aba1776fbaebb22059a54f54d83875e1310dbe3b" alt=""
- ダウンロードしたらXCodeの左メニューのRunnerめがけてドラッグアンドドロップします。すると以下のような画面が表示されるので、「Copy items if neede」、「Create groups」にチェックが入っていることを確かめて、右下の「Finish」をクリックします。
data:image/s3,"s3://crabby-images/a6593/a6593db199c1b2f18684fe127542efc6b26106ea" alt=""
- Android Studio側から見て、ios/Runner/GoogleService-Info.plistが存在することを確認します。このとき、git管理下になっていればgitignoreに追加しておきます。
data:image/s3,"s3://crabby-images/ecaca/ecaca38aacf881c43a8db77a6b30e1cfb337f0b9" alt=""
ここで一度ビルドしてみます。
最低限pubspec.ymlにfirebase_coreを追加してpub getします。
ターミナルで
flutter pub add firebase_core
と打てば追加されます。
以上でiOSでビルドし、通ればiOSは完了です。
Androidアプリの追加
- 次にAndroidアプリを追加します。先程と同様に今度はAndroidのアイコンをクリックします。
data:image/s3,"s3://crabby-images/8aebb/8aebb803de116d3ffec883bb7a5d3c402da3101e" alt=""
- Android Studioに戻り、android/app/build.gradleのdefaultConfig内にあるapplicationIdの中身をコピーします。
data:image/s3,"s3://crabby-images/010be/010beabf9f3111faf3ef2ede5af2d18741b6a316" alt=""
- Firebaseの画面に戻り、先程コピーしたapplicationIdをAndroidパッケージ名に貼り付け、適宜ニックネームをつけて「アプリを登録」をクリックします。
data:image/s3,"s3://crabby-images/a3015/a3015da5dcc7c0a214274ecaf73ac51470f92df9" alt=""
- google-services.jsonをダウンロードし、android/app/google-services.jsonとなるように配置します。
data:image/s3,"s3://crabby-images/7935e/7935ed33ce0ecae2c8f3324606695a3bae481482" alt=""
- android/build.gradleを開き、dependenciesにclasspath ‘com.google.gms:google-services:4.3.8’を追加します。
data:image/s3,"s3://crabby-images/d154b/d154bf18de8989600babc223864329cbb2047dc0" alt=""
- 今度はandroid/app/build.gradleを開きapplyが3つ並んでいる行の下に、apply plugin: ‘com.google.gms.google-services’ を追加します。
data:image/s3,"s3://crabby-images/a2885/a2885c33be8e276d99231b4582ecb95f1ffc73d7" alt=""
- また、android/app/build.gradleのdefaultConfigの一番下にmultiDexEnabled trueを追加し、dependenciesにimplementation ‘com.android.support:multidex:1.0.3’を追加します。
data:image/s3,"s3://crabby-images/78472/7847280908d8b7ed739c9e1fc9a19f5dfab7e8df" alt=""
以上でAndroidの方でビルドできれば完了です。
- 最後にfirebaseを入れた場合は必ず以下のようにmain.dartを書き換える必要があるので、書き換えておきましょう。
void main() async {
WidgetsFlutterBinding.ensureInitialized();
await Firebase.initializeApp();
runApp(MyApp());
}
data:image/s3,"s3://crabby-images/55bff/55bffff5a2ddb6c948f76ba5222cb10ef6cf6e13" alt=""
参考
最新の情報はFlutterFireの公式ページを参照しましょう。
FlutterFire | FlutterFire
The official Firebase plugins for Flutter
コメント