網站首頁 編程語言 正文
集成準備
這是一個基于 MobPush 功能的擴展的 Flutter 插件。使用此插件能夠幫助您在使用 Flutter 開發應用時,快速地實現推送功能。
在pubspec.yaml文件中加入下面依賴
dependencies: mobcommonlib: mobpush_plugin:
然后執行:flutter packages get 導入package 在你的dart工程文件中,導入下面頭文件,開始使用
import 'package:mobcommonlib/mobcommonlib.dart';
import 'package:mobpush_plugin/mobpush_plugin.dart';
iOS
平臺配置參考 iOS集成文檔
實現文檔中 Xcode配置:配置AppKey和AppSecret
Android
導入 MobPush 相關依賴
在項目根目錄的build.gradle中添加以下代碼:
buildscript {
repositories {
// 配置Mob Maven庫
maven {
url "https://mvn.mob.com/android"
}
// 配置HMS Core SDK的Maven倉地址。(集成華為廠商需要添加)
maven {
url 'https://developer.huawei.com/repo/'}
}
...
}
dependencies {
...
// 集成MobPush
classpath "com.mob.sdk:MobSDK:2018.0319.1724"
}
}
在 /android/app/build.gradle 中添加以下代碼:
apply plugin: 'com.android.application'
apply from: "$flutterRoot/packages/flutter_tools/gradle/flutter.gradle"
// 導入MobSDK
apply plugin: 'com.mob.sdk'
平臺相關集成 在項目的/android/app/build.gradle中添加:
MobSDK {
appKey "您的MobTech平臺appKey"
appSecret "您的MobTech平臺appSecret"
//配置MobPush
MobPush {
//配置廠商推送(可選配置,不需要廠商推送可不配置,需要哪些廠商推送只需配置哪些廠商配置即可)
devInfo {
//配置小米廠商推送
XIAOMI {
appId "您的小米平臺appId"
appKey "您的小米平臺appKey"
}
//配置華為廠商推送
HUAWEI {
appId "您的華為平臺appId"
}
//配置魅族廠商推送
MEIZU {
appId "您的魅族平臺appId"
appKey "您的魅族平臺appKey"
}
//配置FCM廠商推送
FCM {
//設置默認推送通知顯示圖標
iconRes "@mipmap/default_ic_launcher"
}
//配置OPPO廠商推送
OPPO {
appKey "您的OPPO平臺appKey"
appSecret "您的OPPO平臺appSecret"
}
//配置VIVO廠商推送
VIVO {
appId "您的VIVO平臺appId"
appKey "您的VIVO平臺appKey"
}
}
}
}
添加代碼
在MainActivity的onCreate中添加以下代碼:
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
GeneratedPluginRegistrant.registerWith(this);
}
SDK API
回傳用戶隱私授權結果 (submitPrivacyGrantResult)
/**
* 回傳用戶隱私授權結果
* @param status 用戶是否同意隱私協議
* @param result 默認傳null
*/
Mobcommonlib.submitPolicyGrantResult(bool status, Function(bool)? result)
例:
Mobcommonlib.submitPolicyGrantResult(true, null);
設置遠程推送環境
向用戶授權(setCustomNotification僅 iOS)
setCustomNotification
if (Platform.isIOS) {
MobpushPlugin.setCustomNotification();
}
設置遠程推送環境 (setAPNsForProduction僅 iOS)
setAPNsForProduction
if (Platform.isIOS) {
// 開發環境 false, 線上環境 true
MobpushPlugin.setAPNsForProduction(false)
}
添加推送回調監聽(addPushReceiver 接收自定義透傳消息回調、接收通知消息回調、接收點擊通知消息回調、接收別名或標簽操作回調)
addPushReceiver
MobpushPlugin.addPushReceiver(_onEvent, _onError);
void _onEvent(Object event) {
}
void _onError(Object event) {
}
停止推送(stopPush)
stopPush
MobpushPlugin.stopPush();
重新打開推送服務(restartPush)
restartPush
MobpushPlugin.restartPush();
是否已停止接收推送(isPushStopped)
isPushStopped
MobpushPlugin.isPushStopped();
設置別名(setAlias)
setAlias
MobpushPlugin.setAlias("別名").then((Map<String, dynamic> aliasMap){
String res = aliasMap['res'];
String error = aliasMap['error'];
String errorCode = aliasMap['errorCode'];
print(">>>>>>>>>>>>>>>>>>>>>>>>>>> setAlias -> res: $res error: $error");
});
獲取別名(getAlias)
getAlias
MobpushPlugin.getAlias().then((Map<String, dynamic> aliasMap){
String res = aliasMap['res'];
String error = aliasMap['error'];
print(">>>>>>>>>>>>>>>>>>>>>>>>>>> getAlias -> res: $res error: $error");
});
刪除別名(deleteAlias)
deleteAlias
MobpushPlugin.deleteAlias().then((Map<String, dynamic> aliasMap){
String res = aliasMap['res'];
String error = aliasMap['error'];
print(">>>>>>>>>>>>>>>>>>>>>>>>>>> deleteAlias -> res: $res error: $error");
});
添加標簽(addTags)
addTags
List tags = new List();
tags.add("tag1");
tags.add("tag2");
MobpushPlugin.addTags(tags).then((Map<String, dynamic> tagsMap){
String res = tagsMap['res'];
String error = tagsMap['error'];
print(">>>>>>>>>>>>>>>>>>>>>>>>>>> addTags -> res: $res error: $error");
});
獲取標簽(getTags)
getTags
MobpushPlugin.getTags().then((Map<String, dynamic> tagsMap) {
List<String> resList;
if (tagsMap['res'] == null) {
resList = [];
} else {
resList = tagsMap['res'].toList();
}
String error = tagsMap['error'];
print(
">>>>>>>>>>>>>>>>>>>>>>>>>>> getTags -> res: $resList error: $error");
});
刪除標簽(deleteTags)
deleteTags
List tags = new List();
tags.add("tag1");
tags.add("tag2");
MobpushPlugin.deleteTags(tags).then((Map<String, dynamic> tagsMap){
String res = tagsMap['res'];
String error = tagsMap['error'];
print(">>>>>>>>>>>>>>>>>>>>>>>>>>> deleteTags -> res: $res error: $error");
});
清空標簽(cleanTags)
cleanTags
MobpushPlugin.cleanTags().then((Map<String, dynamic> tagsMap){
String res = tagsMap['res'];
String error = tagsMap['error'];
print(">>>>>>>>>>>>>>>>>>>>>>>>>>> cleanTags -> res: $res error: $error");
});
發送本地通知(addLocalNotification)
addLocalNotification
MobpushPlugin.addLocalNotification();
綁定手機號(bindPhoneNum)
bindPhoneNum
MobpushPlugin.bindPhoneNum("110");
測試模擬推送,用于測試(send)
send
/**
* 測試模擬推送,用于測試
* type:模擬消息類型,1、通知測試;2、內推測試;3、定時
* content:模擬發送內容,500字節以內,UTF-8
* space:僅對定時消息有效,單位分鐘,默認1分鐘
* extras: 附加數據,json字符串
*/
MobpushPlugin.send(int type, String content, int space, String extras).then((Map<String, dynamic> sendMap){
String res = sendMap['res'];
String error = sendMap['error'];
print(">>>>>>>>>>>>>>>>>>>>>>>>>>> send -> res: $res error: $error");
});
設置點擊通知是否跳轉默認頁 (setClickNotificationToLaunchMainActivity 僅Android)
setClickNotificationToLaunchMainActivity
MobpushPlugin.setClickNotificationToLaunchMainActivity (bool enable);
移除本地通知(removeLocalNotification 僅Android)
removeLocalNotification
MobpushPlugin.removeLocalNotification(int notificationId);
清空本地通知(clearLocalNotifications 僅)
clearLocalNotifications
MobpushPlugin.clearLocalNotifications();
設置通知欄icon,不設置默認取應用icon(setNotifyIcon 僅Android)
setNotifyIcon
MobpushPlugin.setNotifyIcon(String resId);
設置通知靜音時段(推送選項)(setSilenceTime 僅Android)
setSilenceTime
/**
* 設置通知靜音時段(推送選項)(僅Android)
* @param startHour 開始時間[0~23] (小時)
* @param startMinute 開始時間[0~59](分鐘)
* @param endHour 結束時間[0~23](小時)
* @param endMinute 結束時間[0~59](分鐘)
*/
MobpushPlugin.setSilenceTime(int startHour, int startMinute, int endHour, int endMinute)
設置角標 (setBadge僅 iOS)
setBadge
MobpushPlugin.setBadge(int badge);
清空角標,不清除通知欄消息記錄 (clearBadge僅 iOS)
clearBadge
MobpushPlugin.clearBadge();
獲取注冊Id(getRegistrationId)
getRegistrationId
MobpushPlugin.getRegistrationId().then((Map<String, dynamic> ridMap) {
print(ridMap);
String regId = ridMap['res'].toString();
print('------>#### registrationId: ' + regId);
});
Flutter iOS端注意事項
由于插件更新,SDK的Pod依賴被替換,Flutter 本身寫入Pod文件不會先執行刪除原有依賴,導致可能會出現原有本地庫依然存在,請檢查Pod文件夾下文件,直接手動刪除mob_pushsdk 以及 MOBFoundation文件即可,如有疑問,請直接通過官網和我們聯系。
demo地址?GitHub地址
原文鏈接:https://juejin.cn/post/7170274114929147934
相關推薦
- 2022-08-02 Redis跳躍表的基本原理和實現_Redis
- 2022-05-01 大數據Spark?Sql中日期轉換FROM_UNIXTIME和UNIX_TIMESTAMP的使用_數
- 2023-02-06 C++11中longlong超長整型和nullptr初始化空指針_C 語言
- 2022-06-26 Git配置.gitignore文件忽略被指定的文件上傳_相關技巧
- 2022-04-09 Object 轉Map,Map轉Object方式總結
- 2022-10-18 C++中智能指針最常用的shared_ptr和unique_ptr_C 語言
- 2022-03-24 C++數組和指針的區別與聯系_C 語言
- 2022-07-16 Date 轉為 LocalDate
- 最近更新
-
- window11 系統安裝 yarn
- 超詳細win安裝深度學習環境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權
- redisson分布式鎖中waittime的設
- maven:解決release錯誤:Artif
- restTemplate使用總結
- Spring Security之安全異常處理
- MybatisPlus優雅實現加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發現-Nac
- Spring Security之基于HttpR
- Redis 底層數據結構-簡單動態字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支