開發工具:Android Studio
集成方式:Gradle在線集成
安卓版本支持:minSdkVersion 19
集成準備
注冊賬號
使用PushSDK之前,需要先在MobTech官網注冊開發者賬號,并獲取MobTech提供的AppKey和AppSecret,詳情可以點擊查看注冊流程
MobPush后臺配置
注冊MobTech賬號后,需要在MobTech后臺進行相關信息的配置,詳情可以點擊查看具體配置信息
MobPush流程圖
集成配置
MobPushSDK提供了兩種集成方式,您可根據需要進行選擇。需要注意的是,兩種集成方式在功能上無任何區別,僅為集成方式不同,選取其中一種即可。
Gradle集成
配置SDK地址
Android Studio的代碼庫配置方式隨Gradle插件的不同版本有所不同。請根據您當前Gradle插件的版本,選擇相應的配置方式。
【7.0及以上版本】
打開項目級“settings.gradle”文件,配置Maven倉地址,注意修改 repositoriesMode為 RepositoriesMode.PREFER_SETTINGS。
pluginManagement { repositories { gradlePluginPortal() google() mavenCentral() maven { url "https://mvn.mob.com/android" } } } dependencyResolutionManagement { // repositoriesMode.set(RepositoriesMode.FAIL_ON_PROJECT_REPOS) repositoriesMode.set(RepositoriesMode.PREFER_SETTINGS) repositories { gradlePluginPortal() google() mavenCentral() maven { url "https://mvn.mob.com/android" } } }
打開Android Studio項目級build.gradle文件,配置MobSDK插件地址
buildscript { dependencies { // 增加MobSDK插件配置 classpath "com.mob.sdk:MobSDK2:+" // 增加google services插件配置,用于集成FCM,不集成FCM可不配置 classpath 'com.google.gms:google-services:4.3.14' } } plugins { id 'com.android.application' version 'x.x.x' apply false id 'com.android.library' version 'x.x.x' apply false }
【7.0以下版本】
打開Android Studio項目級build.gradle文件。
在allprojects ->repositories里面配置maven倉地址。
allprojects { repositories { maven { url "https://mvn.mob.com/android" } } }
在buildscript->repositories中配置maven倉地址。
buildscript { repositories { maven { url "https://mvn.mob.com/android" } } }
在buildscript->dependencies中配置AppGallery Connect插件地址
buildscript { dependencies { //增加MobSDK插件配置 classpath "com.mob.sdk:MobSDK2:+" } }
添加依賴
打開應用級的build.gradle文件。
添加mob插件配置。請根據實際情況選擇:
方式一:在“com.android.application” 插件下一行添加如下配置。
apply plugin: 'com.mob.sdk'
方式二:在“plugins”中添加如下配置。
plugins { id 'com.android.application' id 'com.mob.sdk' }
在文件末尾添加mob配置代碼
MobSDK { appKey "替換為MobTech官方申請的appkey" appSecret "替換為MobTech官方申請的appkey對應的appSecret" MobPush {} }
配置標識
在gradle.properties中添加代碼
MobSDK.spEdition=IZNAO
Google Play 版本
如果您的應用需要上架Google商店,請務必使用Google Play 版本。
在gradle.properties中添加代碼,如已添加 MobSDK.spEdition相關配置,則修改值為 GPP即可。
MobSDK.spEdition=GPP
至此,Gradle集成方式已經完成。
離線集成
獲取SDK
在進行離線集成之前,請先聯系在線客服獲取離線SDK。
添加SDK
把獲取到的離線SDK包放入項目中的libs文件夾內。
引入SDK
通過上一步添加SDK至項目中后,SDK包還未進行引用,需要添加下方所示引入代碼后才可使用。
implementation fileTree(dir: 'libs', include: ['*.aar', '*.jar'])
配置清單文件
復制下方提供的清單文件代碼至您的項目AndroidManifest.xml文件中。
------ end 需要添加的內容 end ------?> /application?> /manifest?>
至此,離線集成方式已經完成。
配置混淆代碼
在項目中添加如下混淆代碼
-keep class com.mob.**{*;} -dontwarn com.mob.**
隱私授權啟動業務
為保證您的App在集成MobSDK之后能夠滿足工信部相關合規要求,您應確保App安裝首次冷啟動且取得用戶閱讀您《隱私政策》授權之后,調用 MobSDK.submitPolicyGrantResult回傳隱私協議授權結果。
反之,如果用戶不同意您App《隱私政策》授權,則不能調用 MobSDK.submitPolicyGrantResult回傳隱私協議授權結果。 請參考MobPush隱私政策
通用方案
/** * com.mob.MobSDK.class * 回傳用戶隱私授權結果 * @param isGranted 用戶是否同意隱私協議 */ public static void submitPolicyGrantResult(boolean isGranted)
增加App數據采集主動控制器方案
/** * com.mob.MobSDK.class * 回傳用戶隱私授權結果 * @param isGranted App數據采集主動控制器子類實例 * @param isGranted 用戶是否同意隱私協議 */ public static void submitPolicyGrantResult(MobCustomController cont, boolean isGranted);
示例代碼
注:submitPolicyGrantResult是MobSDK的業務起點。調用位置開發者可以自己指定,只需在使用SDK功能之前調用即可,強烈建議開發者在終端用戶點擊應用隱私協議彈窗同意按鈕后調用。
App數據采集主動控制器用來限制MobSDK采集并提供可選的數據維度和擴展功能。因相關信息的不收集將會對其對應的功能造成影響,請開發者結合業務實際需要進行合理配置。MobPush擴展業務功能設置可參考: https://www.mob.com/wiki/detailed?wiki=534&id=136 ,其它App數據采集主動控制器的配置方法可參考:https://www.mob.com/wiki/detailed?wiki=664&id=714
MobSDK.submitPolicyGrantResult(new MobCustomController() { // TODO 重寫控制器 }, true); // 或者 MobSDK.submitPolicyGrantResult(true);
日志調試
請在AndroidManifest.xml文件中 下添加上面配置,在日志控制臺即可查看到TAG為MobPushLog的相關日志:
測試確認
確認通過gradle已拉取到資源包,包名為:"com.mob:MobSupportV1:xxxxxxxxx";"com.mob:MobCoreULT:xxxxxxxxx";"com.mob:MobGUIULT:xxxxxxxxx@aar";"com.mob:PushSDK:xxx@aar"
確認 AppKey已經正確的寫入 Androidmanifest.xml(可在app-debug.apk中的Androidmanifest查看確認)
確認測試手機已經調用隱私協議接口,并上傳true : MobSDK.submitPolicyGrantResult(true);
確認測試手機(或者模擬器)已成功連入網絡 + 客戶端調用,不要使用網絡代理和VPN,如果一切正常,啟動項目后應有MobPushLog的日志信息,參考tag如下
功能進階
Registration ID 使用說明
獲取: 關于獲取Registration ID,請點擊查看MobPushSDK API 使用
使用說明: 由于MobPush推送所有形式的推送最后都會轉化為對 Registration ID 推送,因此 Registration ID是推送和關聯用戶信息必備的標識。同時為了方便線上客戶準確提供信息,減少溝通成本,我們建議您完成 SDK 集成后,將Registration ID 進行存儲和記錄,排查問題時可將Registration ID和任務ID一起反饋,可加速排查進度
審核編輯 黃宇
-
SDK
+關注
關注
3文章
1029瀏覽量
45782 -
andriod
+關注
關注
1文章
19瀏覽量
13815
發布評論請先 登錄
相關推薦
評論