Flutter Firebase 不保留用户身份验证

Posted

技术标签:

【中文标题】Flutter Firebase 不保留用户身份验证【英文标题】:Flutter Firebase does not persist user authentication 【发布时间】:2020-10-19 12:03:53 【问题描述】:

我正在 Flutter 中使用 Firebase 谷歌身份验证创建一个应用。我能够登录到应用程序,但是当我关闭应用程序时,身份验证被删除,需要我重新登录。

这是我的登录屏幕,“使用 Google 登录”按钮将触发 _signInButton() 中的 onPressed()。

import 'package:flutter/material.dart';
import 'package:auth_screen/sign_in.dart';
import 'package:auth_screen/homepage.dart';

class LoginPage extends StatefulWidget 
  @override
  _LoginPageState createState() => _LoginPageState();


class _LoginPageState extends State<LoginPage> 
  @override
  Widget build(BuildContext context) 
    return Scaffold(
      body: Container(
        color: Colors.white,
        child: Center(
          child: Column(
            mainAxisSize: MainAxisSize.max,
            mainAxisAlignment: MainAxisAlignment.center,
            children: <Widget>[
              Image(image: AssetImage("assets/thelogo.jpg"), height: 200.0),
              SizedBox(height: 25),
             _signInButton(),
            ],
          ),
        ),
      ),
    );
  

  Widget _signInButton() 
    return OutlineButton(
      splashColor: Colors.grey,
      onPressed: () 
        signInWithGoogle().whenComplete(() 
          Navigator.of(context).push(
            MaterialPageRoute(
              builder: (context) 
                return MyHomePage();
              ,
            ),
          );
      );
      ,
     shape: RoundedRectangleBorder(borderRadius: BorderRadius.circular(40)),
      highlightElevation: 0,
      borderSide: BorderSide(color: Colors.grey),
      child: Padding(
        padding: const EdgeInsets.fromLTRB(0, 10, 0, 10),
        child: Row(
          mainAxisSize: MainAxisSize.min,
          mainAxisAlignment: MainAxisAlignment.center,
          children: <Widget>[
            Image(image: AssetImage("assets/google_logo.png"), height: 35.0),
            Padding(
              padding: const EdgeInsets.only(left: 10),
              child: Text(
                'Sign in with Google',
                style: TextStyle(
                  fontSize: 20,
                  color: Colors.grey,
                ),
              ),
            )
          ],
        ),
      ),
    );
  

这是所有 Google 和 Firebase 执行身份验证的页面。

import 'package:firebase_auth/firebase_auth.dart';
import 'package:google_sign_in/google_sign_in.dart';
import 'package:cloud_firestore/cloud_firestore.dart';

final FirebaseAuth _auth = FirebaseAuth.instance;
final GoogleSignIn googleSignIn = GoogleSignIn();

String name;
String email;
String imageUrl;

Future<String> signInWithGoogle() async 

  final GoogleSignInAccount googleSignInAccount = await googleSignIn.signIn();
  final GoogleSignInAuthentication googleSignInAuthentication = await googleSignInAccount.authentication;

  final AuthCredential credential = GoogleAuthProvider.getCredential(
    accessToken: googleSignInAuthentication.accessToken,
    idToken: googleSignInAuthentication.idToken,
  );

  final AuthResult authResult = await _auth.signInWithCredential(credential);
  final FirebaseUser user = authResult.user;

  imageUrl = user.photoUrl;

  assert(!user.isAnonymous);
  assert(await user.getIdToken() != null);

  final FirebaseUser currentUser = await _auth.currentUser();
  assert(user.uid == currentUser.uid);

  //return 'signInWithGoogle succeeded: $user';


void signOutGoogle() async
  await googleSignIn.signOut();
  theID = '';
  print("User Sign Out");

我听说默认情况下 Firebase 会保留用户身份验证,但它不会在我的程序中发生。在我按下注销按钮之前,有什么方法可以使用户身份验证持续存在吗?如果您有任何想法,请告诉我。

【问题讨论】:

【参考方案1】:

Firebase 确实存储持久身份验证,您只需要调用它!

有两种方法可以解决这个问题:

    没有 Shared_pref - 在此方法中,您创建一个启动屏幕,这是您的应用程序的入口点(在此处添加应用程序徽标或其他内容),并在其中检查用户是否已登录然后发送将他转到主屏幕,或者将他发送到登录屏幕。
Future<void> _handleStartScreen() async 
    Auth _auth = Auth();

    if (await _auth.isLoggedIn()) 
      Navigator.popAndPushNamed(context, HomeScreen.id);
     else 
      Navigator.popAndPushNamed(context, WelcomeScreen.id);
    
  

您可以从初始屏幕的 initstate 调用它。

2.使用 Shared_pref:- 这是更常用的方式。在此,您使用包 shared_preferences(https://pub.dev/packages/shared_preferences#-readme-tab-,您可以从给定的链接检查如何使用它)在应用程序中本地存储身份验证状态 因此,每当用户登录时,使用 logged_in = true 在其中存储一个布尔值,并且每当应用程序启动时,您都会从启动屏幕调用 shared_preferences 的实例。 你可以在他注销时切换logged_in var。

【讨论】:

很高兴它对您的查询有所帮助!

以上是关于Flutter Firebase 不保留用户身份验证的主要内容,如果未能解决你的问题,请参考以下文章

Flutter:Firebase身份验证无需登录即可创建用户

Flutter - 将 Firebase 通知推送给没有 Firebase 身份验证的特定用户

使用 Flutter 的 Firebase 身份验证不起作用

Flutter Firebase 身份验证和/或登录不成功

持久化用户身份验证 Flutter Firebase

在 Flutter 中使用 Firebase 身份验证检查用户是不是是新用户