Android使用Apple和Firebase进行登录的Flutter
创始人
2024-10-10 13:31:56
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'),

相关内容

热门资讯

保存时出现了1个错误,导致这篇... 当保存文章时出现错误时,可以通过以下步骤解决问题:查看错误信息:查看错误提示信息可以帮助我们了解具体...
汇川伺服电机位置控制模式参数配... 1. 基本控制参数设置 1)设置位置控制模式   2)绝对值位置线性模...
不能访问光猫的的管理页面 光猫是现代家庭宽带网络的重要组成部分,它可以提供高速稳定的网络连接。但是,有时候我们会遇到不能访问光...
不一致的条件格式 要解决不一致的条件格式问题,可以按照以下步骤进行:确定条件格式的规则:首先,需要明确条件格式的规则是...
本地主机上的图像未显示 问题描述:在本地主机上显示图像时,图像未能正常显示。解决方法:以下是一些可能的解决方法,具体取决于问...
表格列调整大小出现问题 问题描述:表格列调整大小出现问题,无法正常调整列宽。解决方法:检查表格的布局方式是否正确。确保表格使...
表格中数据未显示 当表格中的数据未显示时,可能是由于以下几个原因导致的:HTML代码问题:检查表格的HTML代码是否正...
Android|无法访问或保存... 这个问题可能是由于权限设置不正确导致的。您需要在应用程序清单文件中添加以下代码来请求适当的权限:此外...
【NI Multisim 14...   目录 序言 一、工具栏 🍊1.“标准”工具栏 🍊 2.视图工具...
银河麒麟V10SP1高级服务器... 银河麒麟高级服务器操作系统简介: 银河麒麟高级服务器操作系统V10是针对企业级关键业务...