gpt4 book ai didi

firebase - 持久化用户身份验证 Flutter Firebase

转载 作者:IT老高 更新时间:2023-10-28 12:40:19 25 4
gpt4 key购买 nike

我在 Flutter 中使用 Firebase Auth 和谷歌登录。我可以登录,但是当我关闭应用程序(杀死它)时,我必须重新注册。那么有没有办法保持用户身份验证直到用户特别注销?这是我的身份验证类(class)

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

class Auth {
FirebaseAuth _firebaseAuth;
FirebaseUser _user;

Auth() {
this._firebaseAuth = FirebaseAuth.instance;
}

Future<bool> isLoggedIn() async {
this._user = await _firebaseAuth.currentUser();
if (this._user == null) {
return false;
}
return true;
}

Future<bool> authenticateWithGoogle() async {
final googleSignIn = GoogleSignIn();
final GoogleSignInAccount googleUser = await googleSignIn.signIn();
final GoogleSignInAuthentication googleAuth =
await googleUser.authentication;
this._user = await _firebaseAuth.signInWithGoogle(
accessToken: googleAuth.accessToken,
idToken: googleAuth.idToken,
);
if (this._user == null) {
return false;
}
return true;
// do something with signed-in user
}
}

这是我调用身份验证检查的起始页面。

import 'package:flutter/material.dart';
import 'auth.dart';
import 'login_screen.dart';
import 'chat_screen.dart';

class Splash extends StatefulWidget {

@override
_Splash createState() => _Splash();
}

class _Splash extends State<Splash> {

@override
Widget build(BuildContext context) {
return Scaffold(
body: Center(
child: CircularProgressIndicator(
value: null,
),
),
);
}

@override
void initState() {
super.initState();
_handleStartScreen();
}

Future<void> _handleStartScreen() async {
Auth _auth = Auth();
if (await _auth.isLoggedIn()) {
Navigator.of(context).pushReplacementNamed("/chat");
}
Navigator.pushReplacement(context, MaterialPageRoute(builder: (BuildContext context) => LoginScreen(auth: _auth,)));
}
}

最佳答案

我相信你的问题是路由。在我的应用程序中,我使用 FirebaseAuth 并且它可以按照您所说的那样工作,并且我不会保留任何登录 token 。但是,我不知道为什么您使用 getUser 的方法不起作用。

尝试调整您的代码以使用 onAuthStateChanged。编辑:截至 2022 年,使用 Flutter 3,我注意到它使用 userChanges 效果更好。

基本上,在您的 MaterialApp 上,创建一个 StreamBuilder 监听 _auth.userChanges() 并根据 Auth 状态选择您的页面。

我将复制并粘贴我的应用程序的部分内容,以便您有所了解:

[...]

final FirebaseAuth _auth = FirebaseAuth.instance;

Future<void> main() async {
FirebaseApp.configure(
name: '...',
options:
Platform.isIOS
? const FirebaseOptions(...)
: const FirebaseOptions(...),
);

[...]

runApp(new MaterialApp(
title: '...',
home: await getLandingPage(),
theme: ThemeData(...),
));
}

Future<Widget> getLandingPage() async {
return StreamBuilder<FirebaseUser>(
stream: _auth.userChanges(),
builder: (BuildContext context, snapshot) {
if (snapshot.hasData && (!snapshot.data!.isAnonymous)) {
return HomePage();
}

return AccountLoginPage();
},
);
}

关于firebase - 持久化用户身份验证 Flutter Firebase,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54469191/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com