簡介:
MobLink是MobTech公司下的一款服務功能。其中包括熟知的ShareSDK,還有SMSSDK、秒驗、MobPush、MobLink。官方解釋:MobLink是移動場景還原解決方案。說簡單些就是分發下載統計的解決方案。其中包括:場景喚醒、多樣化跳轉、無碼邀請、專屬鏈接、來源追溯。
鏈接:http://www.mob.com/mobService/moblink
應用場景:
比如:需要推廣app、活動等,通過不同的活動頁跳轉下載或者轉入app活動頁。一鍵跳轉,統計來源渠道,喚醒,回跳。
集成流程:
- 創建應用,獲取AppKey和AppSecret。
- 應用後臺進行基礎配置。
- App根據應用基礎配置,導入SDK,加入系統庫。
- 代碼調試。
- js配置,啓動一個本地服務。
- 實現場景還原和跳轉。
流程分解:
創建應用時,需要認證開發者:公司或者個人,都可以。然後創建應用獲取AppKey和AppSecret。
需要配置:Team ID、Bundle Id、URL Scheme、下載/引導地址、路由配置。
作爲一個開發者,有一個學習的氛圍跟一個交流圈子特別重要,這是一個我的iOS交流羣:834688868,不管你是大牛還是小白都歡迎入駐 ,分享BAT,阿里面試題、面試經驗,討論技術, 大家一起交流學習成長!
#### **需要注意**
1. Universal Link是MobLink給好的,只需要把它配置在自己工程中,不需要自己創建,注意的點是:你的證書需要支持Universal Link功能,需要你去開發者後臺打開此功能。要不然再填寫Universal Link會證書報錯。
2. URL Scheme 要和app中的保持一致。
3. 路由配置,需要不同的渠道標識,按照他的規則寫入即可,跳轉的頁面一般填寫跳轉的類名,方便在代碼中能一眼識別。
-
配置上述的Universal Link、URL Scheme。
SDK導入:
手動導入,下載demo,把
MobLinkPro.framework
,MOBFoundation.framework
導入工程。-
cocoapods:
pod 'mob_linksdk_pro'
如果搜索不到這個mob_linksdk_pro時:
請先進行:pod setup
再清空一下搜索索引,讓pod重建索引:
rm ~/Library/Caches/CocoaPods/search_index.json
- 添加依賴庫:
libsqlite3
、libz1.2.5
、libc++
-
配置初始化需要的Appkey和AppSecert:在info.plist中添加key、value。
MOBAppKey:寫你的AppKey MOBAppSecret:寫你的AppSecert
-
代碼調試:
- 在需要恢復的控制器類中實現UIViewController+MLSDKRestore的方法
#import <MobLinkPro/MLSDKScene.h> #import <MobLinkPro/UIViewController+MLSDKRestore.h> @property (nonatomic, strong) MLSDKScene *scene; //實現帶有場景參數的初始化方法,並根據場景參數還原該控制器: -(instancetype)initWithMobLinkScene:(MLSDKScene *)scene { if (self = [super init]) { self.scene = scene; } return self; }
解釋:每一個需要跳轉的頁面都需要實現這個方法,不實現是不會自動跳轉的。這個scene就是在這個頁面你需要的參數。參數在哪裏配置後面會講。
-
實現場景還原回調
MobLink在運行的時候會通過delegate將整個運作過程呈現出來,所有的delegate方法都不是必須實現的,但這些delegate能夠幫助您實現更多自定義的操作。代碼如下:
#import <MobLinkPro/IMLSDKRestoreDelegate.h> #import <MobLinkPro/MobLink.h> #import <MobLinkPro/MLSDKScene.h> @interface AppDelegate () <IMLSDKRestoreDelegate> - (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions { // 設置MobLink代理 [MobLink setDelegate:self]; return YES; }
導入頭文件,繼承代理,設置代理,實現代理方法。
- (void)IMLSDKWillRestoreScene:(MLSDKScene *)scene IMLSDKWillRestoreScene:(void (^)(BOOL, RestoreStyle))restoreHandler { NSLog(@"Will Restore Scene - Path:%@",scene.path); NSLog(@"className - %@", scene.className); restoreHandler(YES, MLDefault); } - (void)IMLSDKCompleteRestore:(MLSDKScene *)scene { NSLog(@"Complete Restore -Path:%@",scene.path); } - (void)IMLSDKNotFoundScene:(MLSDKScene *)scene { NSLog(@"Not Found Scene - Path :%@",scene.path); UIAlertView *alertView = [[UIAlertView alloc] initWithTitle:@"沒有找到路徑" message:[NSString stringWithFormat:@"Path:%@",scene.path] delegate:self cancelButtonTitle:@"OK" otherButtonTitles:nil]; [alertView show]; }
其中restorehandler第一個參數表示是否自動進行場景恢復,第二個參數表示推出模式。
到這裏!app集成已經完成!
需要注意
這三個方法,看名字是能一目瞭然的,但是現在mob他們做了修改,可能文檔還沒有修改,目前他們的scene.path是不會返回的,所以先走
IMLSDKWillRestoreScene:IMLSDKWillRestoreScene:
再走IMLSDKNotFoundScene:
方法,大家也不要大驚小怪,其實是回調成功的。只不過不返回path了,那這裏可以從返回的scene.classname獲取要跳轉的類,這就是上面說的後臺配置類名能一目瞭然。
-
web js配置
在mob後臺的頁面配置->引用js文件中找到你專屬的js文件,裏面有他們後臺給你配置js後臺文件
<script type="text/javascript" src="//atff.t4m.cn/applink.js"></script>
中的//atff.t4m.cn/applink.js
就是專屬你自己的。配置在你html中,保存,啓動服務。
怎樣配置服務、啓動這裏就不說了。
把你服務的鏈接分享到不同的渠道,然後去點擊打開,如果是本地有app,則直接喚起,然後會自動跳入你配置的頁面,如果沒有,則會跳到你後臺配置的下載/引導地址中。
這時候你就可以從後臺統計不同的渠道來源。
存在問題:
- js不是很穩定,配置了path,啓動服務後,有時候無法跳轉app。
- link新增:測試發現後臺沒有統計,詢問後還需要優化,後期開發中。
作爲一個開發者,有一個學習的氛圍跟一個交流圈子特別重要,這是一個我的iOS交流羣:834688868,不管你是大牛還是小白都歡迎入駐 ,分享BAT,阿里面試題、面試經驗,討論技術, 大家一起交流學習成長!
以下資料在羣文件可自行下載!
作者:宇軒Simid
鏈接:https://www.jianshu.com/p/b29d77a2a5a3