iOS-MobLink集成流程

簡(jiǎn)介:

MobLink是MobTech公司下的一款服務(wù)功能。其中包括熟知的ShareSDK,還有SMSSDK、秒驗(yàn)、MobPush、MobLink。官方解釋:MobLink是移動(dòng)場(chǎng)景還原解決方案。說簡(jiǎn)單些就是分發(fā)下載統(tǒng)計(jì)的解決方案。其中包括:場(chǎng)景喚醒、多樣化跳轉(zhuǎn)、無碼邀請(qǐng)、專屬鏈接、來源追溯。
鏈接:http://www.mob.com/mobService/moblink

應(yīng)用場(chǎng)景:

比如:需要推廣app、活動(dòng)等,通過不同的活動(dòng)頁跳轉(zhuǎn)下載或者轉(zhuǎn)入app活動(dòng)頁。一鍵跳轉(zhuǎn),統(tǒng)計(jì)來源渠道,喚醒,回跳。

集成流程:

  1. 創(chuàng)建應(yīng)用,獲取AppKey和AppSecret。
  2. 應(yīng)用后臺(tái)進(jìn)行基礎(chǔ)配置。
  3. App根據(jù)應(yīng)用基礎(chǔ)配置,導(dǎo)入SDK,加入系統(tǒng)庫。
  4. 代碼調(diào)試。
  5. js配置,啟動(dòng)一個(gè)本地服務(wù)。
  6. 實(shí)現(xiàn)場(chǎng)景還原和跳轉(zhuǎn)。

流程分解:

  1. 創(chuàng)建應(yīng)用時(shí),需要認(rèn)證開發(fā)者:公司或者個(gè)人,都可以。然后創(chuàng)建應(yīng)用獲取AppKey和AppSecret。

  2. 需要配置:Team ID、Bundle Id、URL Scheme、下載/引導(dǎo)地址、路由配置。

    需要注意

    1. Universal Link是MobLink給好的,只需要把它配置在自己工程中,不需要自己創(chuàng)建,注意的點(diǎn)是:你的證書需要支持Universal Link功能,需要你去開發(fā)者后臺(tái)打開此功能。要不然再填寫Universal Link會(huì)證書報(bào)錯(cuò)。
    2. URL Scheme 要和app中的保持一致。
    3. 路由配置,需要不同的渠道標(biāo)識(shí),按照他的規(guī)則寫入即可,跳轉(zhuǎn)的頁面一般填寫跳轉(zhuǎn)的類名,方便在代碼中能一眼識(shí)別。
  3. 配置上述的Universal Link、URL Scheme。

    SDK導(dǎo)入:

    1. 手動(dòng)導(dǎo)入,下載demo,把MobLinkPro.framework,MOBFoundation.framework導(dǎo)入工程。

    2. cocoapods:

      pod 'mob_linksdk_pro'
      

      如果搜索不到這個(gè)mob_linksdk_pro時(shí):

      1. 請(qǐng)先進(jìn)行:pod setup

      2. 再清空一下搜索索引,讓pod重建索引:

      rm ~/Library/Caches/CocoaPods/search_index.json
      
      1. 添加依賴庫:libsqlite3、libz1.2.5libc++
    3. 配置初始化需要的Appkey和AppSecert:在info.plist中添加key、value。

      MOBAppKey:寫你的AppKey
      MOBAppSecret:寫你的AppSecert
      
  4. 代碼調(diào)試:

    1. 在需要恢復(fù)的控制器類中實(shí)現(xiàn)UIViewController+MLSDKRestore的方法
    #import <MobLinkPro/MLSDKScene.h>
    #import <MobLinkPro/UIViewController+MLSDKRestore.h>
    
    @property (nonatomic, strong) MLSDKScene *scene;
    
    //實(shí)現(xiàn)帶有場(chǎng)景參數(shù)的初始化方法,并根據(jù)場(chǎng)景參數(shù)還原該控制器:
    -(instancetype)initWithMobLinkScene:(MLSDKScene *)scene
    {
        if (self = [super init]) {
            self.scene = scene;
        }
        return self;
    }
    

    解釋:每一個(gè)需要跳轉(zhuǎn)的頁面都需要實(shí)現(xiàn)這個(gè)方法,不實(shí)現(xiàn)是不會(huì)自動(dòng)跳轉(zhuǎn)的。這個(gè)scene就是在這個(gè)頁面你需要的參數(shù)。參數(shù)在哪里配置后面會(huì)講。

    1. 實(shí)現(xiàn)場(chǎng)景還原回調(diào)

      MobLink在運(yùn)行的時(shí)候會(huì)通過delegate將整個(gè)運(yùn)作過程呈現(xiàn)出來,所有的delegate方法都不是必須實(shí)現(xiàn)的,但這些delegate能夠幫助您實(shí)現(xiàn)更多自定義的操作。代碼如下:

      #import <MobLinkPro/IMLSDKRestoreDelegate.h>
      #import <MobLinkPro/MobLink.h>
      #import <MobLinkPro/MLSDKScene.h>
      @interface AppDelegate () <IMLSDKRestoreDelegate>
      - (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions {
           // 設(shè)置MobLink代理
           [MobLink setDelegate:self];
           return YES;
      }
      

      導(dǎo)入頭文件,繼承代理,設(shè)置代理,實(shí)現(xiàn)代理方法。

      - (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第一個(gè)參數(shù)表示是否自動(dòng)進(jìn)行場(chǎng)景恢復(fù),第二個(gè)參數(shù)表示推出模式。

      到這里!app集成已經(jīng)完成!

      需要注意

      這三個(gè)方法,看名字是能一目了然的,但是現(xiàn)在mob他們做了修改,可能文檔還沒有修改,目前他們的scene.path是不會(huì)返回的,所以先走IMLSDKWillRestoreScene:IMLSDKWillRestoreScene:再走IMLSDKNotFoundScene:方法,大家也不要大驚小怪,其實(shí)是回調(diào)成功的。只不過不返回path了,那這里可以從返回的scene.classname獲取要跳轉(zhuǎn)的類,這就是上面說的后臺(tái)配置類名能一目了然。

  5. web js配置

    在mob后臺(tái)的頁面配置->引用js文件中找到你專屬的js文件,里面有他們后臺(tái)給你配置js后臺(tái)文件<script type="text/javascript" src="http://atff.t4m.cn/applink.js"></script>中的//atff.t4m.cn/applink.js就是專屬你自己的。

    配置在你html中,保存,啟動(dòng)服務(wù)。

    怎樣配置服務(wù)、啟動(dòng)這里就不說了。

  6. 把你服務(wù)的鏈接分享到不同的渠道,然后去點(diǎn)擊打開,如果是本地有app,則直接喚起,然后會(huì)自動(dòng)跳入你配置的頁面,如果沒有,則會(huì)跳到你后臺(tái)配置的下載/引導(dǎo)地址中。

這時(shí)候你就可以從后臺(tái)統(tǒng)計(jì)不同的渠道來源。

存在問題:

  1. js不是很穩(wěn)定,配置了path,啟動(dòng)服務(wù)后,有時(shí)候無法跳轉(zhuǎn)app。
  2. link新增:測(cè)試發(fā)現(xiàn)后臺(tái)沒有統(tǒng)計(jì),詢問后還需要優(yōu)化,后期開發(fā)中。
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

友情鏈接更多精彩內(nèi)容