【发布时间】:2020-12-29 05:36:09
【问题描述】:
我正在使用 Flutter Web 开发一个网络应用。
每次我刷新页面时,都会触发 onAuthStateChanges 并执行仅在身份验证状态发生更改时才应触发的功能。
这种行为是有意的吗?
为了订阅 onAuthStateChanges,我用一个有状态的小部件包装了我的主小部件并监听了 onAuthStateChanges,如下所示: Flutter Stream Builder Triggered when Navigator Pop or Push is Called
以下是我的代码:
我的包装:
/// Wrapper for stateful functionality to provide onInit calls in stateles widget
class StatefulWrapper extends StatefulWidget {
final Function onInit;
final Widget child;
const StatefulWrapper({@required this.onInit, @required this.child});
@override
_StatefulWrapperState createState() => _StatefulWrapperState();
}
class _StatefulWrapperState extends State<StatefulWrapper> {
@override
void initState() {
if (widget.onInit != null) {
widget.onInit();
}
super.initState();
}
@override
Widget build(BuildContext context) {
return widget.child;
}
}
我在 main.dart 中的小部件:
Widget build(BuildContext context) {
var router = MyRouter.Router();
var authenticationService = locator<AuthenticationService>();
var sharedPreferences = locator<SharedPreferencesService>();
return StatefulWrapper(
onInit: () {
authenticationService.listenToAuthChanges();
},
child: FutureBuilder(
future: sharedPreferences.getSharedPreferences('ruolo'),
builder: (context, snapshot) {
return MaterialApp(
builder: ExtendedNavigator<MyRouter.Router>(
initialRoute: MyRouter.Routes.startupView,
guards: [AuthGuard(), AdminGuard()],
router: router,
navigatorKey: locator<NavigationService>().navigatorKey,
),
title: 'Flutter Demo',
theme: ThemeData(
primarySwatch: Colors.blue,
visualDensity: VisualDensity.adaptivePlatformDensity,
),
onGenerateRoute: router.onGenerateRoute,
);
}),
);
}
这是来自 authenticationService 的方法:
void listenToAuthChanges() {
FirebaseAuth.instance.authStateChanges().listen((firebaseUser) async {
if (firebaseUser == null) {
navigationService.navigateTo(Routes.login);
} else {
navigationService.replaceWith(Routes.home);
}
});
}
当我在浏览器中刷新页面时,会触发此函数的侦听器,如果我没有登录,它会导航到登录,否则在主页上。
这是故意的吗?对我来说,只有当它收听的内容发生变化时,监听器才应该触发。
【问题讨论】:
-
如果您刷新页面,您实际上是在重新启动整个应用程序。这是有意的,否则你无法在启动时获得身份验证状态。
-
好吧,但是为什么会触发函数的handler呢?对我来说,这对我来说没有任何意义。
-
我的意思是,只有当该事件发生时才应该触发侦听器的处理程序。当我刷新时,我的登录状态没有改变,它和以前一样。
-
如果他们将其删除,则无法确定应用启动时的身份验证状态。当您刷新网页时,它不会“记住”之前的身份验证状态。您正在重新启动整个应用程序。
标签: firebase flutter firebase-authentication flutter-web