添加这个迟到的答案,因为现在有一个 package、flutter_facebook_login 替换 flutter_facebook_connect。这是一个正常运行的main.dart 示例,应该可以。请记住,您必须按照存储库中的说明遵循所有 configuration,并且必须配置 facebook 应用程序:
import 'package:flutter/material.dart';
import 'package:flutter_facebook_login/flutter_facebook_login.dart';
import 'dart:async';
void main() => runApp(new MyApp());
class MyApp extends StatelessWidget {
@override
Widget build(BuildContext context) {
return new MaterialApp(
title: 'Flutter Facebook Login',
theme: new ThemeData(
primarySwatch: Colors.blue,
),
home: new MyHomePage(title: 'Flutter Login Facebook'),
);
}
}
class MyHomePage extends StatefulWidget {
MyHomePage({Key key, this.title}) : super(key: key);
final String title;
@override
_MyHomePageState createState() => new _MyHomePageState();
}
class _MyHomePageState extends State<MyHomePage> {
login() async {
final facebookLogin = new FacebookLogin();
final result = await facebookLogin.logInWithReadPermissions(['email']);
switch (result.status) {
case FacebookLoginStatus.loggedIn:
print(result.accessToken.token);
break;
case FacebookLoginStatus.cancelledByUser:
print('CANCELED BY USER');
break;
case FacebookLoginStatus.error:
print(result.errorMessage);
break;
}
}
@override
Widget build(BuildContext context) {
return new Scaffold(
appBar: new AppBar(
title: new Text(widget.title),
),
floatingActionButton: new FloatingActionButton(
onPressed: login,
tooltip: 'Login With Facebook',
child: new Icon(Icons.add),
),
);
}
}
单击右下角按钮时应该会看到登录屏幕,并在调试控制台上检查打印的响应:
这是现在要走的路,因为该软件包实际上在 Android 和 iOS 上使用原生 Facebook 登录 SDK。所以没有借口使用 Firebase 或必须自己接口!
希望它可以帮助其他在 facebook 登录方面遇到问题的人。积分归包创建者roughike
google 登录使用google_sign_in,这个包其实已经相当成熟,也更容易上手。