🎄teratailクリスマスプレゼントキャンペーン2024🎄』開催中!

\teratail特別グッズやAmazonギフトカード最大2,000円分が当たる!/

詳細はこちら
Firebase

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

Flutter

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

ログイン

ログインは、ユーザーがコンピューターシステムにアクセスするプロセスの事を呼びます。

Dart

Dartは、Googleによって開発されたJavaScriptの代替となることを目的に作られた、ウェブ向けのプログラミング言語である。

Google

Googleは、アメリカ合衆国に位置する、インターネット関連のサービスや製品を提供している企業です。検索エンジンからアプリケーションの提供まで、多岐にわたるサービスを提供しています。

Q&A

1回答

667閲覧

flutterでfirebaseを使ったgoogleログイン

su_da221

総合スコア59

Firebase

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

Flutter

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

ログイン

ログインは、ユーザーがコンピューターシステムにアクセスするプロセスの事を呼びます。

Dart

Dartは、Googleによって開発されたJavaScriptの代替となることを目的に作られた、ウェブ向けのプログラミング言語である。

Google

Googleは、アメリカ合衆国に位置する、インターネット関連のサービスや製品を提供している企業です。検索エンジンからアプリケーションの提供まで、多岐にわたるサービスを提供しています。

0グッド

0クリップ

投稿2020/12/30 12:11

こちらを参考にして、firebaseを使用したgoogleログイン機能を実装したいのですが、デバッグモード にするとエラーが出ます。

vscode内デバッグコンソール
イメージ説明

firebase関連でエラーが出てるのはわかるのですが解決方法が何も出てこないので、教えてほしいです。

main.dart

import 'package:flutter/material.dart'; import 'package:firebase_auth/firebase_auth.dart'; import 'package:google_sign_in/google_sign_in.dart'; class MyHomePage extends StatefulWidget { MyHomePage({Key key, this.title}) : super(key: key); final String title; @override _MyHomePageState createState() => _MyHomePageState(); } class _MyHomePageState extends State<MyHomePage> { final GoogleSignIn _googleSignIn = GoogleSignIn(); final FirebaseAuth _auth = FirebaseAuth.instance; Future<FirebaseUser> _handleSignIn() async { GoogleSignInAccount googleCurrentUser = _googleSignIn.currentUser; try { if (googleCurrentUser == null) googleCurrentUser = await _googleSignIn.signInSilently(); if (googleCurrentUser == null) googleCurrentUser = await _googleSignIn.signIn(); if (googleCurrentUser == null) return null; GoogleSignInAuthentication googleAuth = await googleCurrentUser.authentication; final AuthCredential credential = GoogleAuthProvider.getCredential( accessToken: googleAuth.accessToken, idToken: googleAuth.idToken, ); final FirebaseUser user = (await _auth.signInWithCredential(credential)).user; print("signed in " + user.displayName); return user; } catch (e) { print(e); return null; } } void transitionNextPage(FirebaseUser user) { if (user == null) return; Navigator.push(context, MaterialPageRoute(builder: (context) => NextPage(userData: user))); } @override Widget build(BuildContext context) { return Scaffold( appBar: AppBar( title: Text(widget.title), ), body: Center( child: Column( mainAxisAlignment: MainAxisAlignment.center, children: <Widget>[ RaisedButton( child: Text('Sign in Google'), onPressed: () { _handleSignIn() .then((FirebaseUser user) => transitionNextPage(user)) .catchError((e) => print(e)); }, ), ]), ), ); } } class NextPage extends StatefulWidget { FirebaseUser userData; NextPage({Key key, this.userData}) : super(key: key); @override _NextPageState createState() => _NextPageState(userData); } class _NextPageState extends State<NextPage> { FirebaseUser userData; String name = ""; String email; String photoUrl; final GoogleSignIn _googleSignIn = GoogleSignIn(); _NextPageState(FirebaseUser userData) { this.userData = userData; this.name = userData.displayName; this.email = userData.email; this.photoUrl = userData.photoUrl; } Future<void> _handleSignOut() async { await FirebaseAuth.instance.signOut(); try { await _googleSignIn.signOut(); } catch (e) { print(e); } Navigator.pop(context); } @override Widget build(BuildContext context) { return Scaffold( appBar: AppBar( title: Text("ユーザー情報表示"), ), body: Center( child: Column( mainAxisAlignment: MainAxisAlignment.center, children: <Widget>[ Image.network(this.photoUrl), Text( this.name, style: TextStyle( fontSize: 24, ), ), Text( this.email, style: TextStyle( fontSize: 24, ), ), RaisedButton( child: Text('Sign Out Google'), onPressed: () { _handleSignOut().catchError((e) => print(e)); }, ), ]), ), ); } }

pubspec.yml

dependencies: flutter: sdk: flutter firebase_core: ^0.5.3 firebase_auth: ^0.18.4+1 google_sign_in: ^4.5.6

main.dartの <FirebaseUser> に青い波線も出ています。

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

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

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

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

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

guest

回答1

0

一度Podをクリアしてみたら解決しませんか?

rm -rf ios/Podfile.lock ios/Pods ios/Podfile

投稿2020/12/31 02:20

aya-eiya

総合スコア97

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

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

ただいまの回答率
85.36%

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

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

質問する

関連した質問