news 2026/6/22 22:31:02

Flutter 基于Firebase的鉴权功能集成

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Flutter 基于Firebase的鉴权功能集成

Firebase提供了一套SDK用于抹平不用平台鉴权的差异性,为了方便使用,将基于firebase_auth、google_sign_in、sign_in_with_apple的依赖封装一套登录统一的功能集成。

鉴权后将会获取idToken,该数据需要传给服务器进行校验。

步骤:

1.定义模块最终返回的数据结构

class FirebaseAuthInfo { String? idToken; String? providerId; FirebaseAuthInfo({this.idToken, this.providerId}); Map toJson() { return {"idToken": idToken, "providerId": providerId}; } }

2. 定义工具类,提供login和logout方法

enum LoginType { google, apple, phone, email } class LoginMethod { late LoginType loginType; factory LoginMethod(LoginType loginType) => LoginMethod._(loginType); LoginMethod._(this.loginType) { switch (loginType) { case LoginType.google: break; case LoginType.apple: break; case LoginType.phone: break; case LoginType.email: break; } } Future login() async { switch (loginType) { case LoginType.google: return await _googleSign(); case LoginType.apple: return await _appleSign(); case LoginType.phone: return; case LoginType.email: return; } } void logout() { switch (loginType) { case LoginType.google: _googleOut(); break; case LoginType.apple: break; case LoginType.phone: break; case LoginType.email: break; } } }

3. 基于Firebase Email的鉴权方法(该方法调用时,Android和IOS需要配置对应SchemeUrl,通过Applink才能实现)

Future<FirebaseAuthInfo?> verifyEmail(String email, Uri uri) async { if (FirebaseAuth.instance.isSignInWithEmailLink(uri.toString())) { try { final firebaseAuth = await FirebaseAuth.instance .signInWithEmailLink(email: email, emailLink: uri.toString()); var idToken = await firebaseAuth.user?.getIdToken(); return Future.value(FirebaseAuthInfo( idToken: idToken, providerId: firebaseAuth.credential?.providerId)); } catch (error) { print('Error signing in with email link.'); } return null; } else { return null; } }

4. 基于Firebase Phone的鉴权方法(验证码条数需要Firebase console中配置)

Future<FirebaseAuthInfo?> phoneSign(String code, String phone) async { Completer<FirebaseAuthInfo?> completer = Completer(); await FirebaseAuth.instance.verifyPhoneNumber( phoneNumber: '$code $phone', verificationCompleted: (PhoneAuthCredential credential) async { final firebaseAuth = await FirebaseAuth.instance.signInWithCredential(credential); var idToken = await firebaseAuth.user?.getIdToken(); if (!completer.isCompleted) { completer.complete(FirebaseAuthInfo( idToken: idToken, providerId: firebaseAuth.credential?.providerId)); } }, verificationFailed: (FirebaseAuthException e) { if (!completer.isCompleted) { completer.complete(null); } }, codeSent: (String verificationId, int? resendToken) {}, codeAutoRetrievalTimeout: (String verificationId) { if (!completer.isCompleted) { completer.complete(null); } }, ); return completer.future; }

5. 基于Google Account的鉴权方法(获取账户信息的作用域请查询官方文档),如需要每次登录都可以选择指定的google账号的动作,需要登录前先登出,否则本地有缓存,下次调用将直接复用上一次的账号信息。

void _googleOut() { try { var googleSignIn = GoogleSignIn( scopes: <String>[ 'https://www.googleapis.com/auth/userinfo.email', "https://www.googleapis.com/auth/userinfo.profile" ], ); googleSignIn.signOut(); } catch (e) {} } Future<FirebaseAuthInfo?> _googleSign() async { try { var googleSignIn = GoogleSignIn( scopes: <String>[ 'https://www.googleapis.com/auth/userinfo.email', "https://www.googleapis.com/auth/userinfo.profile" ], ); await googleSignIn.signOut(); var googleAccountInfo = await googleSignIn.signIn(); var googleAuth = await googleAccountInfo?.authentication; if (googleAuth != null) { var firebaseAuth = await FirebaseAuth.instance .signInWithCredential(GoogleAuthProvider.credential( accessToken: googleAuth.accessToken, idToken: googleAuth.idToken, )); var idToken = await firebaseAuth.user?.getIdToken(); return FirebaseAuthInfo( idToken: idToken, providerId: firebaseAuth.credential?.providerId); } else { return Future.value(); } } catch (e) { debugPrint("Auth error !:${e.toString()}"); } return null; } }

6. 基于Apple Account的鉴权方法

Future<FirebaseAuthInfo?> _appleSign() async { try { final appleIdCredential = await SignInWithApple.getAppleIDCredential( scopes: [ AppleIDAuthorizationScopes.email, ], ); final oAuthProvider = OAuthProvider('apple.com'); final credential = oAuthProvider.credential( idToken: appleIdCredential.identityToken, accessToken: appleIdCredential.authorizationCode, ); var identify = await FirebaseAuth.instance.signInWithCredential(credential); var idToken = await identify.user?.getIdToken(); return FirebaseAuthInfo(idToken: idToken, providerId: "apple.com"); } catch (e) { debugPrint("Auth error !:${e.toString()}"); } return null; }
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/23 14:11:43

彻底解放游戏束缚:ER-Save-Editor让你成为真正的存档编辑大师

彻底解放游戏束缚&#xff1a;ER-Save-Editor让你成为真正的存档编辑大师 【免费下载链接】ER-Save-Editor Elden Ring Save Editor. Compatible with PC and Playstation saves. 项目地址: https://gitcode.com/GitHub_Trending/er/ER-Save-Editor 你是否曾在交界地的征…

作者头像 李华
网站建设 2026/6/23 14:17:13

AI如何帮你快速搭建Tomcat8开发环境?

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容&#xff1a; 生成一个自动化脚本&#xff0c;用于快速搭建和配置Tomcat8开发环境。脚本应包括以下功能&#xff1a;自动下载Tomcat8安装包、解压到指定目录、配置环境变量、设置默认端口为8080、…

作者头像 李华
网站建设 2026/6/23 1:17:46

终极指南:如何用Threema Android实现完全私密通讯

终极指南&#xff1a;如何用Threema Android实现完全私密通讯 【免费下载链接】threema-android Threema App for Android. 项目地址: https://gitcode.com/gh_mirrors/th/threema-android 在数字隐私日益受到威胁的今天&#xff0c;Threema Android作为一款专注于安全通…

作者头像 李华
网站建设 2026/6/23 7:03:32

交叉注意力在医疗影像诊断中的突破性应用

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容&#xff1a; 开发一个医疗影像诊断辅助系统原型&#xff0c;使用交叉注意力机制关联CT扫描图像和患者电子病历。功能包括&#xff1a;1. 影像特征提取&#xff1b;2. 文本病历处理&#xff1b;3…

作者头像 李华
网站建设 2026/6/23 14:19:00

39、保障Web服务器安全:从安装到配置的全流程指南

保障Web服务器安全:从安装到配置的全流程指南 在当今数字化时代,Web服务器的安全性至关重要。一个安全的Web服务不仅能保护用户数据,还能确保网站的正常运行。本文将详细介绍Web服务器安全的相关知识,包括需要保障安全的方面、一些基本原则,以及Apache服务器的安装和配置…

作者头像 李华
网站建设 2026/6/23 16:08:00

5步构建去中心化能源交易平台:从概念验证到规模化部署

想象一下这样的场景&#xff1a;你家的屋顶光伏板在阳光明媚的下午产生了过剩的电力&#xff0c;而隔壁邻居刚好需要为他的电动汽车充电。在传统能源体系下&#xff0c;这些清洁电力只能以低价卖给电网&#xff0c;然后邻居以高价从电网购电。这种低效的交易模式正是当前能源系…

作者头像 李华