Flutter接入Firebase推送


1
2
3
其实在网上也能搜到一些教程,但是不是讲的不清楚,就是版本太老,此次使用的Flutter版本是2.0.0,
理论上Flutter版本大于1.12皆适用。
本文大部分按照官方Firebase接入方式,主要做了cloud message,其他插件原理类似。
注意:因项目问题,本文只描述了Android端的接入(后期有空会增加iOS端的接入)

官方文档链接

1.引入firebase_core包

1)、在pubspec.yaml文件中添加firebase_core的引入(此时最新的)

1
firebase_core: ^1.0.3

执行

1
flutter pub get

2)、在Firebase 中创建新项目,并按提示添加bundleId与SHA-1值(SHA-1值后面做推送测试用),然后下载生成的google-services.json文件,并将其放置在[项目]/android/app/中。

3)、安装Firebase配置文件

首先,在android/build.gradle中添加google-services的支持:

1
2
3
4
5
6
buildscript {
dependencies {
// ... other dependencies
classpath 'com.google.gms:google-services:4.3.3'
}
}

接着在/android/app/build.gradle中的apply plugin: ‘com.android.application’紧跟着下方添加:

1
apply plugin: 'com.google.gms.google-services'

4)、编译运行项目

添加以下测试是否报错

1
await Firebase.initializeApp();

example:

1
2
3
4
5
6
7
8
9
10
11
void main() {
//statusBar设置为透明,去除半透明遮罩
WidgetsFlutterBinding.ensureInitialized();

initFirebase();

}
void initFirebase() async{
await Firebase.initializeApp();//初始化Firebase组件
initApp();//调用UI逻辑
}

2.引入firebase_messaging包

参考FirebaseMessage接入

1)、在pubspec.yaml添加最新版本

1
firebase_messaging: ^9.1.1

执行

1
flutter pub get

2)、此时注意官方提醒,Flutter版本大于1.12的话那就什么配置也无需操作,因急于2.0版本,因此小于1.12的情况不做讨论

1
If you are using Flutter Android Embedding V2 (Flutter Version >= 1.12) then no additional integration steps are required for Android.

3)、初始化firebase_message(注意:调用前必须先初始化firebase_core)

1
2
3
void initFireMessage() async{
FirebaseMessaging messaging = FirebaseMessaging.instance;
}

4)、获取token绑定(如果能获取到token证明接入成功)

1
2
3
FirebaseMessaging.instance.getToken().then((value){
print('token==='+value);
});

5)、监听消息

1
2
3
4
5
6
///应用启动时的消息提示
FirebaseMessaging.instance.getInitialMessage().then((RemoteMessage message){
if (message != null){
print(message.data.toString());
}
});

1
2
3
4
5
///应用前台收到消息红点提示或跳转
FirebaseMessaging.onMessage.listen((RemoteMessage message) {
RemoteNotification notification = message.notification;
///消息操作
});
1
2
3
4
5
///通知栏消息点击进入消息详情
FirebaseMessaging.onMessageOpenedApp.listen((RemoteMessage message) {


});

在程序入口处添加以下代码:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
///后台收消息启动给红点提示
Future<void> _firebaseMessagingBackgroundHandler(RemoteMessage message) async {
await Firebase.initializeApp();
print("Handling a background message: ${message.messageId}");
}
void main() {
WidgetsFlutterBinding.ensureInitialized();
initFirebase();
}
void initFirebase() async{
await Firebase.initializeApp();
FirebaseMessaging.onBackgroundMessage(_firebaseMessagingBackgroundHandler);
initApp();///程序入口
}

以上就是简单的步骤;接着就可以去Firebase后台 中的Cloud Messaging中测试发布消息。

具体消息处理按自己项目要求出处理。


文章作者: Flonger
版权声明: 本博客所有文章除特別声明外,均采用 CC BY 4.0 许可协议。转载请注明来源 Flonger !
 本篇
Flutter接入Firebase推送 Flutter接入Firebase推送
123其实在网上也能搜到一些教程,但是不是讲的不清楚,就是版本太老,此次使用的Flutter版本是2.0.0,理论上Flutter版本大于1.12皆适用。本文大部分按照官方Firebase接入方式,主要做了cloud message,其他插
下一篇 
关于Git上传的报错 关于Git上传的报错
在每次上传图片或者文件时报错,报错信息如下:12345678910Enumerating objects: 79, done.Counting objects: 100% (69/69), done.Delta compression us
2020-01-07
  目录