質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.46%
Firebase

Firebaseは、Googleが提供するBasSサービスの一つ。リアルタイム通知可能、並びにアクセス制御ができるオブジェクトデータベース機能を備えます。さらに認証機能、アプリケーションのログ解析機能などの利用も可能です。

Flutter

Flutterは、iOSとAndroidのアプリを同じコードで開発するためのフレームワークです。オープンソースで開発言語はDart。双方のプラットフォームにおける高度な実行パフォーマンスと開発効率を提供することを目的としています。

Q&A

解決済

2回答

2989閲覧

flutter no firebase app default has been createdの解決方法

bowtin

総合スコア10

Firebase

Firebaseは、Googleが提供するBasSサービスの一つ。リアルタイム通知可能、並びにアクセス制御ができるオブジェクトデータベース機能を備えます。さらに認証機能、アプリケーションのログ解析機能などの利用も可能です。

Flutter

Flutterは、iOSとAndroidのアプリを同じコードで開発するためのフレームワークです。オープンソースで開発言語はDart。双方のプラットフォームにおける高度な実行パフォーマンスと開発効率を提供することを目的としています。

0グッド

0クリップ

投稿2021/11/13 15:43

解決したいこと

  • FlutterからFirestoreデータの読み書きを行いたい

困っていること

  • main.dartからFireStoreにアクセスしようとするとエラー「flutter no firebase app default has been created」が発生する

試したこと

  • main関数内でFirebase.initializeApp()を呼び出す → 改善せず
  • Flutterのアプリを1から構築し、FireStoreにアクセスするコードだけを書いてみた → 改善せず
  • main関数の戻り値をvoidではなくFuture<void>に変更 → 改善せず

推測

  • 下記コード内のmain.dartの通り、Firebase.initializeApp()の前後に出力文を挟むとhogeのみ出力される
  • fugaは出力されず、例外「flutter no firebase app default has been created」が発生する

以上より、Flutter.initializeApp()自体がこの例外を引き起こしているように見えます。
初期化を呼び出さなくても同一例外が発生し、初期化を呼び出しても状況は改善されません。
初期化メソッド自体が同じ例外を投げてきます。

コード

yaml

1#pubpsec.yml 2 cupertino_icons: ^1.0.2 3 firebase_core: ^1.10.0 4 cloud_firestore: ^3.1.0

html

1<!-- index.html --> 2 <script type="module"> 3 import { initializeApp } from "https://www.gstatic.com/firebasejs/9.4.1/firebase-app.js"; 4 5 const firebaseConfig = { 6 apiKey: "XXX", 7 authDomain: "XXXX", 8 projectId: "XXXX", 9 storageBucket: "XXXX", 10 messagingSenderId: "XXXX", 11 appId: "XXXX" 12 }; 13 14 // Initialize Firebase 15 const app = initializeApp(firebaseConfig); 16 </script>

dart

1//main.dart(抜粋) 2Future<void> main() async { 3 print("hoge"); 4 // Fireabse初期化 5 Firebase.initializeApp(); 6 print("fuga"); 7 runApp(MyApp()); 8}

どなたか、お助けいただけると嬉しいです!

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答2

0

自分の場合ですが、同様のエラーが起きた時に

main() async { WidgetsFlutterBinding.ensureInitialized();//追加 // Fireabse初期化 //Firebase.initializeApp();//これはrunAppの中で実行する為にMyAppの中に移動 runApp(MyApp()); }

という感じの対処をした覚えがあります。

https://api.flutter.dev/flutter/widgets/WidgetsFlutterBinding/ensureInitialized.html

投稿2021/11/13 16:27

hentaiman

総合スコア6426

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

bowtin

2021/11/13 16:42

早速ありがとうございます!! mainでinitializeAppを呼ぶのではなく、ensureだけしておいてあとから呼び出す感じですね。 ```dart Future<void> main() async { WidgetsFlutterBinding.ensureInitialized(); //追加 // Fireabse初期化 // await Firebase.initializeApp(); runApp(MyApp()); } ``` ```dart class _MyHomePageState extends State<MyHomePage> { int _counter = 0; void initializeFirebaseApp() async { print("hoge"); await Firebase.initializeApp(); print("fuga"); } Widget build(BuildContext context) { initializeFirebaseApp(); return Scaffold(/* 省略 */); } } ``` やはり、```hoge```のみ出力されるためそもそもinitializeApp()で例外吐いている気がしますね...。 せっかく回答頂いたのにすみません。。。
hentaiman

2021/11/13 16:49

firebaseと関係あるのかどうかすら覚えてないのですが、回答したもの以外だと、最新バージョンのパッケージだとエラーが出てバージョン下げたらエラーが出なくなったって事もあります この情報が役に立つかは分かりませんが
bowtin

2021/11/13 17:31

お付き合いいただきありがとうございます。 このあたりのバージョンまで下げてみましたが、特に変わらず・・・。 firebase_core: ^1.9.0 cloud_firestore: ^2.5.0 過去に類似にものを開発したことがあるので、思い切って当時のバージョンまで落としてみました。 こちらも特に変わらずでした。 firebase_core: ^0.5.0 cloud_firestore: ^0.14.0 なお、過去に開発した類似プロジェクトのほうはFirebase Hostingでホストしていたのですが、そちらもシレッといつの間に動かなくなっていました....。
guest

0

自己解決

解決しました。

<script> import { initializeApp } from "firebase/app"; // Import the functions you need from the SDKs you need // TODO: Add SDKs for Firebase products that you want to use // https://firebase.google.com/docs/web/setup#available-libraries // Your web app's Firebase configuration const firebaseConfig = { apiKey: "XXX", authDomain: "XXX", projectId: "XXX", storageBucket: "XXX", messagingSenderId: "XXX", appId: "XXX" }; // Initialize Firebase const app = firebase.initializeApp(firebaseConfig); </script>

index.htmlにこのような記載をしていました。これはFirebaseでアプリを一つ作成すると、これを貼り付けろと言われるスニペットです。

結論として先頭行のimport { initializeApp } from "firebase/app"が不要でした。
これのせいでDart側で書いているFirebase.initializeApp()と併せて二重にinitializeされていたことが原因のようでした。

ならば何故Dart側でinitialzeをしていない時にinitializeされていない扱いだったのか...それはよくわかりません。

イマイチ腑に落ちないのと、理解として正しいのかは確実でないですが改善はしました。
お騒がせしました。

投稿2021/11/13 23:14

編集2021/11/13 23:15
bowtin

総合スコア10

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.46%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問