Firebaseをflutterに入れる手順とその際に発生するエラーについてまとめています。
前提条件
Firebaseのアカウントが既に作成されていることを念頭に解説します。
Firabaseでアプリの登録
プロジェクトの追加
Firebaseのページにいき、プロジェクトを追加します。
data:image/s3,"s3://crabby-images/fc62d/fc62db0c88ef786ce56dfd88f5be81b74bd5604f" alt=""
iOSアプリの追加
プロジェクトを選択し、iosボタンを押してください。
data:image/s3,"s3://crabby-images/374b0/374b04a3f2b5ab87d71f9e5e015574a5cd9302c4" alt=""
AppleバンドルIDを入力し、「アプリを登録」を押します。
data:image/s3,"s3://crabby-images/8fc7c/8fc7ccf950e2e698846c3ddcba6b8aa54d5e97cd" alt=""
バンドルIDは、Runnerを開き、TARGETS>Generalに記載されています。
data:image/s3,"s3://crabby-images/ecf44/ecf44eff2f1a81239842691676cf8227f6b355fa" alt=""
設定ファイルのダウンロード
GoogleService-Info.plistをダウンロードします。
data:image/s3,"s3://crabby-images/c58b0/c58b0ffe3fa052968c2bac5bdd2366ffc3c3b481" alt=""
ダウンロードしたファイルを、下記のようにRunnnerフォルダにドラッグします。
data:image/s3,"s3://crabby-images/d744c/d744c7162c60a007171b14489c572594de4a2c78" alt=""
GoogleService-info.plistは、必ずXcodeで移動させてください。Android Studioなどでファイル移動させると、後でfirebaseを使う際に、”Firebase has not been correctly initialized”というエラーが出てしまいます。参考↓
Flutterの場合は、以上で設定は終了です。
Androidアプリの追加
プロジェクトページにいき、Androidマークのボタンを押してください。
data:image/s3,"s3://crabby-images/cdc18/cdc18e91b10f750afcba2279050df0d6f3fe2161" alt=""
AndroidパッケージIDを追加し、アプリを登録を押します。パッケージIDはandroid>app>build.gradleのapplicationIDに書いてあります。
data:image/s3,"s3://crabby-images/94a75/94a75606736b816dc7815f7c87411f1c3045aef4" alt=""
設定ファイルの追加
google-services.jsonをダウンロードします。
data:image/s3,"s3://crabby-images/4d5df/4d5df84a2c96f3ad545c3cbbd6bca6c8da03a183" alt=""
ダウンロードしたファイルを、appフォルダ内に追加します。
data:image/s3,"s3://crabby-images/357dc/357dc22331036f6a84f56b2a1ff8989738a3af95" alt=""
build.gradleの追加
android>build.gradleに、classpath 'com.google.gms:google-services:4.3.10'
を追加します。
dependencies {
classpath 'com.google.gms:google-services:4.3.10' //これを追加
classpath 'com.android.tools.build:gradle:4.1.0'
classpath "org.jetbrains.kotlin:kotlin-gradle-plugin:$kotlin_version"
}
アプリレベルのbuild.gradleへの追加
android>app>build.gradleに、下記を追加します。dependenciesは、一番下に記載されてあるので{}内を追加してください。
apply plugin: 'com.google.gms.google-services'
dependencies {
implementation platform('com.google.firebase:firebase-bom:29.2.1')
implementation 'com.google.firebase:firebase-analytics'
}
firebaseパッケージの追加
flutter pub add
で、以下のパッケージを追加します。
・firebase_core
・firebase_analytics
・firebase_auth
・cloud_firestore
最後にflutter pub get
を実行します。
パッケージの追加方法がわからない方は下記記事をご覧ください。
data:image/s3,"s3://crabby-images/db344/db344b46c5e80be56948a6c5256fe58eeb5262b7" alt=""
ここまで終わったら、準備は完了です。
実際に実行→エラーが起きるかも。
実際に実行してみます。この際、iOSもAndroidどちらでも実行しておいてください。
エラーがたくさん出てくると思うので解決方法をまとめておきます。
iOSバージョンを指定して!と言われる場合
Automatically assigning platform iOS
with version 9.0
on target Runner
because no platform was specified. Please specify a platform for this target in your Podfile.
と言われる場合は、Podfileでバージョンが指定されていないか、指定されているバージョンが古すぎます。Podfileの一番上にある文章の#を消して、新しいバージョンを指定しましょう。
data:image/s3,"s3://crabby-images/64be3/64be35991ddf9d6097ee0b39c466e203ce3c904a" alt=""
パッケージが古いわ!と言われる場合
Error: Cannot run with sound null safety, because the following dependencies don’t support null safety
とか、下記のようにdepends on both firebase_auth ^0.20.1 and build_runner ^2.1.7, version solving failed.と出る場合は、パッケージが古すぎることが原因です。パッケージをアップデートしましょう。
data:image/s3,"s3://crabby-images/e7018/e7018fcb80c1a89d20a55cf0382e06a972756b7a" alt=""
minSdkVersionが古いわ!と言われる場合
uses-sdk:minSdkVersion 16 cannot be smaller than version 19 declared in library
と言われる場合は、app階層のbuild.gradleに書いてあるminSdkVersionを新しいものにする必要があります。
data:image/s3,"s3://crabby-images/ca2ab/ca2ab1c1efd50f060815c56097631d1e582ed435" alt=""
.javaが推奨されないAPIを使ってますとか安全じゃないですとか出る場合
FlutterFirebaseAnalyticsPlugin.javaは推奨されないAPIを使用またはオーバーライドしています
上記のようなメッセージが出た場合は、minSdkVersionが古い場合があります。app>build.gradleのminSdkVersionを25など新しいものにしましょう。2022年2月現在は25でokですが、もっと新しくする必要があるかもしれません。
data:image/s3,"s3://crabby-images/a9dcc/a9dcc5b6ebe73ce4c2814ef60adb4a27a7620cb6" alt=""
methodsが多い!と言われる場合
Cannot fit requested classes in a single dex file(# methods: 106047 > 65536)
などと言われる場合は、multiDexEnabledをtrueにしてください。
data:image/s3,"s3://crabby-images/ec5bc/ec5bc8311a57c2803b0b60d851580b6fd6500412" alt=""
firebaseをコードで実装する
さて、コードに実際に書いてみましょう。firebaseを使用する際は、下記のようにFutureBuilder()
を用いて記載します。
class App extends StatelessWidget {
@override
Widget build(BuildContext context){
return FutureBuilder{
future: Firebase.initializeApp(),
builder: (context, snapshot){
if (snapshot.hasError){
return Text("SomethingWentWriong");
}
if (snapshot.connectionState == ConnectionState.done){
return MyHomePage();
}
return Text("Loading");
},
);
}
}
このように記載しないと、下記のようなエラーが表示されます。
No Firebase App ‘[DEFAULT]’ has been created – call Firebase.initializeApp()
firebaseを利用したいクラス内で、変数を宣言します。
final _firestore = FirebaseFirestore.instance;
Cloud databaseを使ってデータを格納する方法
上記のように_firestore
を宣言したクラス内かつ上位のクラス(MyApp()等)にFutureBuilder
が宣言されている場合は、下記のようにしてデータを操作することができます。
Firebaseでデータベースを作成
プロジェクトのページにいき、左から”Firestore Database”を選択し、データベースの作成を押します。
data:image/s3,"s3://crabby-images/5c503/5c5031f5e4757740753d9517eb84e474bb5a1d8d" alt=""
テストモードで開始する、を押します(アプリを公開する際には、セキュリティルールを変更する必要があります。)
data:image/s3,"s3://crabby-images/2950a/2950a2d06aff32c58fa16a62fedf2c2b9e8b3498" alt=""
データベースの場所を選びます。デフォルトで問題ありません。
data:image/s3,"s3://crabby-images/140d9/140d9aa5e57b85029f05848e41b1317e9e0fd5f5" alt=""
データの追加
_firestore.collection("questions").add({
'question': '質問です',
'answer': '答えです',})
data:image/s3,"s3://crabby-images/e153b/e153bf7d1ebcb4fa2d9c72a0f79770567c7a13da" alt=""
なお、collection()内に入れるのは、firebaseのcloud Firestoreにあるコレクション名です。存在しない名前を入れれば新規追加されます。
データをリストに格納する場合
データを得る場合は、下記のように記載します。
child: ListView(
children: snapshot.data!.docs.map((DocumentSnapshot document) {
Map<String, dynamic> data = document.data()! as Map<String, dynamic>;
return Card(
color: Colors.white,
child: ListTile(
title: Text(data['question'], textAlign: TextAlign.center,),
trailing: Text((data['answer']==0 )? "×": "○",
style: TextStyle(fontSize: 30),),
),
);
}).toList(),
),
上記のように打つと、dataという変数として使うことができるようになります。
参考ページ
公式ページにも詳しく載っています。興味ある方は読んでみてください。
コメント