flutter_jpush
Flutter 版本 jpush(极光推送),经过热心网友帮助,终于开发完成,目前功能比较稳定,已经上到pub。
ROADMAP
- ios
- android
- 集成notification
- 集成message
- 集成alias
- 集成tags
- 后台接口放出服务
- 可以运行的例子
- 用户可相互自行推送
准备工作
申请key
进入这里申请key
ios 证书申请
不熟悉怎么申请戳这里
集成
ios 集成
ios 修改 AppDelegate.m,新版本一行代码就可以集成了
增加
#include "FlutterJPushPlugin.h"
增加
[self startupJPush:launchOptions appKey:@"你的key" channel:@"你的渠道" isProduction:是否生产版本];
全部的AppDelegate.m如下:
#include "AppDelegate.h"
#include "GeneratedPluginRegistrant.h"
#include "FlutterJPushPlugin.h"
@implementation AppDelegate
- (BOOL)application:(UIApplication *)application
didFinishLaunchingWithOptions:(NSDictionary *)launchOptions {
[self startupJPush:launchOptions appKey:@"你的key" channel:@"你的渠道" isProduction:是否生产版本];
[GeneratedPluginRegistrant registerWithRegistry:self];
// Override point for customization after application launch.
return [super application:application didFinishLaunchingWithOptions:launchOptions];
}
@end
android 集成
修改 你的项目目录/android/app/build.gradle
在android/defaultConfig
节点修改manifestPlaceholders
,新增极光推送key配置
android {
.... 你的代码
defaultConfig {
.....
manifestPlaceholders = [
JPUSH_PKGNAME : applicationId,
JPUSH_APPKEY : "你的极光推送key", //JPush上注册的包名对应的appkey.
JPUSH_CHANNEL : "你的推送渠道,如果不知道填写developer-default即可",
]
}
API调用
1、启动
dart:
在程序入口处做一下调用
void _startupJpush() async {
print("初始化jpush");
await FlutterJPush.startup();
print("初始化jpush成功");
}
2、获取设备唯一号
jpush在启动的时候会去连接自己的服务器,连接并注册成功之后会返回一个唯一的设备号(registrationId),
有两种方法可以得到
设置一个监听
FlutterJPush.addnetworkDidLoginListener((String registrationId) {
setState(() {
/// 用于推送
print("收到设备号:$registrationId");
this.registrationId = registrationId;
});
});
或者主动去取
await FlutterJPush.getRegistrationID()
主动去取有可能取出来是空的
3、设置tag
每一个设备可以对应多个tag
/// 设置tags
FlutterJPush.setTags( ["tag1","tag2" );
/// 新增tag
JPushResult result = await FlutterJPush.addTags(["tag1","tag2"]);
/// 获取所有tag
FlutterJPush.getAllTags();
4、设置和获取alias
alias为别名,别名一般来说是惟一的。
/// 获取别名
FlutterJPush.getAlias().then((JPushResult result) {
if (result.isOk) {
setState(() {
if (mounted) _text = r.result;
});
}
});
/// 设置别名
JPushResult result = await FlutterJPush.getAlias();
if (result.isOk) {
//设置成功
}
5、收到通知提醒
要处理两个监听,一个是收到了通知提醒,并出现在状态栏上面;一个是用户点击了状态栏上面的提醒,打开通知。
FlutterJPush
.addReceiveNotificationListener((JPushNotification notification) {
setState(() {
/// 收到推送
print("收到推送提醒: $notification");
notificationList.add(notification);
});
});
FlutterJPush
.addReceiveOpenNotificationListener((JPushNotification notification) {
setState(() {
print("打开了推送提醒: $notification");
/// 打开了推送提醒
notificationList.add(notification);
});
});
6、收到自定义消息
消息是服务端发送的一段代码,一般是json格式,app在收到消息之后,一般不直接做前台通知。
设置收到自定义消息的监听
FlutterJPush.addReceiveCustomMsgListener((JPushMessage msg) {
setState(() {
print("收到推送消息提醒: $msg");
/// 打开了推送提醒
notificationList.add(msg);
});
});
7、停止和继续接收消息
/// 停止推送,调用该方法后将不再受到推送
static Future<void> stopPush() async
// 恢复推送功能,停止推送后,可调用该方法重新获得推送能力
static Future<void> resumePush() async
目前这个版本还存在编译问题,flutter官方也在积极解决
真机运行报错couldn't find "libflutter.so"
暂时的解决方法有:
build.gradle设置
ndk{
abiFilters 'armeabi', 'armeabi-v7a'//, 'arm64-v8a'
}
或者可以增加编译选项:
--target-platform android-arm64 或者 --target-platform android-arm