Android使用Apple和Firebase进行登录的Flutter
创始人
2024-10-10 13:31:10
0

要在Flutter中使用Firebase进行登录,并且支持Apple登录,你可以按照以下步骤进行操作:

  1. 添加依赖项: 在Flutter项目的pubspec.yaml文件中,添加以下依赖项:
dependencies:
  firebase_core: ^0.4.0+9
  firebase_auth: ^0.14.0+5
  google_sign_in: ^4.0.7
  apple_sign_in: ^0.1.0

运行flutter pub get以获取依赖项。

  1. 配置Firebase项目: 在Firebase控制台创建一个新的项目,并将Android和iOS应用添加到该项目中。在Android应用中,下载并添加google-services.json文件。在iOS应用中,下载并添加GoogleService-Info.plist文件。

  2. 配置Android项目: 在Android项目的android/build.gradle文件中,添加以下代码:

dependencies {
    // ...
    classpath 'com.google.gms:google-services:4.2.0'
}

在Android项目的android/app/build.gradle文件的底部添加以下代码:

apply plugin: 'com.google.gms.google-services'
  1. 配置iOS项目: 在iOS项目的ios/Podfile文件中添加以下代码:
pod 'Firebase/Auth'

然后运行以下命令来安装依赖项:

cd ios
pod install
  1. 配置Flutter代码: 在Flutter项目的lib/main.dart文件中,添加以下代码示例:
import 'package:flutter/material.dart';
import 'package:firebase_core/firebase_core.dart';
import 'package:firebase_auth/firebase_auth.dart';
import 'package:google_sign_in/google_sign_in.dart';
import 'package:apple_sign_in/apple_sign_in.dart';

void main() async {
  WidgetsFlutterBinding.ensureInitialized();
  await Firebase.initializeApp();
  runApp(MyApp());
}

class MyApp extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      title: 'Flutter Firebase Login',
      theme: ThemeData(
        primarySwatch: Colors.blue,
      ),
      home: LoginPage(),
    );
  }
}

class LoginPage extends StatelessWidget {
  final FirebaseAuth _auth = FirebaseAuth.instance;
  final GoogleSignIn _googleSignIn = GoogleSignIn();

  Future signInWithGoogle() async {
    final GoogleSignInAccount googleUser = await _googleSignIn.signIn();
    final GoogleSignInAuthentication googleAuth = await googleUser.authentication;

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

    final UserCredential userCredential = await _auth.signInWithCredential(credential);
    return userCredential;
  }

  Future signInWithApple() async {
    final AuthorizationResult result = await AppleSignIn.performRequests([
      AppleIdRequest(requestedScopes: [Scope.email, Scope.fullName])
    ]);

    switch (result.status) {
      case AuthorizationStatus.authorized:
        final AuthCredential credential = OAuthProvider('apple.com').credential(
          idToken: String.fromCharCodes(result.credential.identityToken),
          accessToken: String.fromCharCodes(result.credential.authorizationCode),
        );

        final UserCredential userCredential = await _auth.signInWithCredential(credential);
        return userCredential;
      case AuthorizationStatus.error:
        throw FirebaseAuthException(
          code: 'apple_sign_in_failed',
          message: result.error.toString(),
        );
      case AuthorizationStatus.cancelled:
        throw FirebaseAuthException(
          code: 'apple_sign_in_cancelled',
          message: 'Sign in with Apple has been cancelled by the user.',
        );
    }
  }

  @override
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(
        title: Text('Flutter Firebase Login'),
      ),
      body: Center(
        child: Column(
          mainAxisAlignment: MainAxisAlignment.center,
          children: [
            RaisedButton(
              onPressed: () async {
                try {
                  final UserCredential userCredential = await signInWithGoogle();
                  print('User signed in with Google: ${userCredential.user.displayName}');
                } catch (e) {
                  print('Failed to sign in with Google: $e');
                }
              },
              child: Text('Sign in with Google'),
            ),
            RaisedButton(
              onPressed: () async {
                try {
                  final UserCredential userCredential = await signInWithApple();
                  print('User signed in with Apple: ${userCredential.user.displayName}');
                } catch (e) {
                  print('Failed to sign in with Apple: $e');
                }
              },
              child: Text('Sign in with Apple'),

相关内容

热门资讯

黑科技脚本(aapoker俱乐... 黑科技脚本(aapoker俱乐部)外挂透明挂辅助神器(透明挂黑科技)原来真的有挂(确实有挂)-哔哩哔...
黑科技软件(wepoke脚本)... 黑科技软件(wepoke脚本)外挂透明挂辅助插件(透明挂黑科技)竟然真的有挂(有挂教学)-哔哩哔哩1...
黑科技好牌(WPK透视挂)外挂... 黑科技好牌(WPK透视挂)外挂透明挂辅助助手(软件透明挂)原来真的有挂(有挂方针)-哔哩哔哩1、下载...
黑科技存在(Wepoke后台)... 黑科技存在(Wepoke后台)外挂透明挂辅助ai代打(透明挂黑科技)竟然真的有挂(有挂详情)-哔哩哔...
黑科技总结(wepoke最新)... 黑科技总结(wepoke最新)外挂透明挂辅助助手(透视)竟然真的有挂(有挂秘诀)-哔哩哔哩1、完成w...
黑科技中牌率(WPK漏洞)外挂... 黑科技中牌率(WPK漏洞)外挂透明挂辅助器(透明挂黑科技)一直真的是有挂(有挂秘籍)-哔哩哔哩1、进...
黑科技有挂(Wepoke辅助a... 黑科技有挂(Wepoke辅助ai)外挂透明挂辅助ai代打(辅助挂)切实有挂(有挂秘籍)-哔哩哔哩1、...
黑科技讲解(Wepoke大厅房... 黑科技讲解(Wepoke大厅房)外挂透明挂辅助代打(智能ai)一直真的有挂(有挂细节)-哔哩哔哩1、...
黑科技黑科技(红龙扑克)外挂透... 黑科技黑科技(红龙扑克)外挂透明挂辅助设备(辅助挂)切实真的是有挂(有挂方法)-哔哩哔哩1)红龙扑克...
黑科技规律(wepoke挂)外... 黑科技规律(wepoke挂)外挂透明挂辅助器(ai辅助)本来存在有挂(有挂方针)-哔哩哔哩;1、we...