t3n*_*nsa 0 android push-notification flutter remote-notifications firebase-cloud-messaging
所以我更新了firebase_messaging并且我不得不更改我的代码,因为FirebaseMessagin.configure()它已被弃用,现在当我收到通知并单击通知时,它不会打开另一个屏幕。
这就是我实现通知的方式:
Future<void> _firebaseMessagingBackgroundHandler(RemoteMessage message) async {
await Firebase.initializeApp();
print('Handling a background message ${message.messageId}');
}
const AndroidNotificationChannel channel = AndroidNotificationChannel(
'high_importance_channel', // id
'High Importance Notifications', // title
'This channel is used for important notifications.', // description
importance: Importance.high,
);
final FlutterLocalNotificationsPlugin flutterLocalNotificationsPlugin =
FlutterLocalNotificationsPlugin();
Future<void> main() async {
WidgetsFlutterBinding.ensureInitialized();
FirebaseMessaging.onBackgroundMessage(_firebaseMessagingBackgroundHandler);
runApp(MyApp());
}
class MyApp extends StatelessWidget {
const MyApp({Key key}) : super(key: key);
@override
Widget build(BuildContext context) {
return MaterialApp(
title: 'e-R?d?u?i',
debugShowCheckedModeBanner: false,
initialRoute: '/',
routes: {
'/': (_) => MenuScreen(),
'/events': (BuildContext context) => EventsScreen(),
},
);
}
}
class MenuScreen extends StatefulWidget {
@override
_MyAppState createState() => new _MyAppState();
}
Widget build(BuildContext context) {
return Scaffold();
}
@override
void initState() {
super.initState();
FirebaseMessaging.onMessage.listen((RemoteMessage message) {
RemoteNotification notification = message.notification;
AndroidNotification android = message.notification?.android;
if (notification != null && android != null) {
flutterLocalNotificationsPlugin.show(
notification.hashCode,
notification.title,
notification.body,
NotificationDetails(
android: AndroidNotificationDetails(
channel.id,
channel.name,
channel.description,
icon: 'launch_background',
),
));
}
});
FirebaseMessaging.onMessageOpenedApp.listen((RemoteMessage message) {
debugPrint('A new onMessageOpenedApp event was published!');
Navigator.pushNamed(context, '/events');
});
}
}
Run Code Online (Sandbox Code Playgroud)
但是.onMessageOpenedApp当我点击通知时没有被调用,因为我没有debugPrint在我的控制台 (VSCode) 中收到该消息并且我收到以下错误:
D/FLTFireMsgReceiver( 4799): broadcast received for message
W/civic.e_radaut( 4799): Accessing hidden method Landroid/os/WorkSource;->add(I)Z (greylist,test-api, reflection, allowed)
W/civic.e_radaut( 4799): Accessing hidden method Landroid/os/WorkSource;->add(ILjava/lang/String;)Z (greylist,test-api, reflection, allowed)
W/civic.e_radaut( 4799): Accessing hidden method Landroid/os/WorkSource;->get(I)I (greylist, reflection, allowed)
W/civic.e_radaut( 4799): Accessing hidden method Landroid/os/WorkSource;->getName(I)Ljava/lang/String; (greylist, reflection, allowed)
W/FirebaseMessaging( 4799): Notification Channel set in AndroidManifest.xml has not been created by the app. Default value will be used.
I/flutter ( 4799): Handling a background message 0:1617783965733220%2ebdcc762ebdcc76
Run Code Online (Sandbox Code Playgroud)
我从 Firebase 发送了我的通知,click_action: FLUTTER_NOTIFICATION_CLICK并在我的清单中添加了
<intent-filter>
<action android:name="FLUTTER_NOTIFICATION_CLICK" />
<category android:name="android.intent.category.DEFAULT" />
</intent-filter>
Run Code Online (Sandbox Code Playgroud)
我的firebase_messaging版本是^8.0.0-dev.15
所以我不知道我错过了什么或者为什么它不起作用。如果您需要更多详细信息,请随时询问。
我通过使用该.getInitialMessage()函数解决了这个问题(如果应用程序终止,这是回调。当应用程序处于后台但未终止时,我的通知有效。
为了解决这个问题,我只是将它添加到我的代码中:
FirebaseMessaging.instance
.getInitialMessage()
.then((RemoteMessage message) {
if (message != null) {
Navigator.pushNamed(context, message.data['view']);
}
});
Run Code Online (Sandbox Code Playgroud)
我在这里做了一个工作演示
| 归档时间: |
|
| 查看次数: |
1820 次 |
| 最近记录: |