iOS-MobLink集成流程

简介:

MobLink是MobTech公司下的一款服务功能。其中包括熟知的ShareSDK,还有SMSSDK、秒验、MobPush、MobLink。官方解释:MobLink是移动场景还原解决方案。说简单些就是分发下载统计的解决方案。其中包括:场景唤醒、多样化跳转、无码邀请、专属连接、来源追溯。javascript

连接:www.mob.com/mobService/…html

应用场景:

好比:须要推广app、活动等,经过不一样的活动页跳转下载或者转入app活动页。一键跳转,统计来源渠道,唤醒,回跳。java

集成流程:

  1. 建立应用,获取AppKey和AppSecret。
  2. 应用后台进行基础配置。
  3. App根据应用基础配置,导入SDK,加入系统库。
  4. 代码调试。
  5. js配置,启动一个本地服务。
  6. 实现场景还原和跳转。

流程分解:

  1. 建立应用时,须要认证开发者:公司或者我的,均可以。而后建立应用获取AppKey和AppSecret。c++

  2. 须要配置:Team ID、Bundle Id、URL Scheme、下载/引导地址、路由配置。web

    须要注意

    1. Universal Link是MobLink给好的,只须要把它配置在本身工程中,不须要本身建立,注意的点是:你的证书须要支持Universal Link功能,须要你去开发者后台打开此功能。要否则再填写Universal Link会证书报错。
    2. URL Scheme 要和app中的保持一致。
    3. 路由配置,须要不一样的渠道标识,按照他的规则写入便可,跳转的页面通常填写跳转的类名,方便在代码中能一眼识别。
  3. 配置上述的Universal Link、URL Scheme。objective-c

    SDK导入:sql

    1. 手动导入,下载demo,把MobLinkPro.frameworkMOBFoundation.framework导入工程。json

    2. cocoapods:bash

      pod 'mob_linksdk_pro'
      复制代码

      若是搜索不到这个mob_linksdk_pro时:markdown

      1. 请先进行:pod setup

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

      rm ~/Library/Caches/CocoaPods/search_index.json
      复制代码
      1. 添加依赖库:libsqlite3libz1.2.5libc++
    3. 配置初始化须要的Appkey和AppSecert:在info.plist中添加key、value。

      MOBAppKey:写你的AppKey
      MOBAppSecret:写你的AppSecert
      复制代码
  4. 代码调试:

    1. 在须要恢复的控制器类中实现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就是在这个页面你须要的参数。参数在哪里配置后面会讲。

    1. 实现场景还原回调

      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获取要跳转的类,这就是上面说的后台配置类名能一目了然。

  5. web js配置

    在mob后台的页面配置->引用js文件中找到你专属的js文件,里面有他们后台给你配置js后台文件<script type="text/javascript" src="//atff.t4m.cn/applink.js"></script>中的//atff.t4m.cn/applink.js就是专属你本身的。

    配置在你html中,保存,启动服务。

    怎样配置服务、启动这里就不说了。

  6. 把你服务的连接分享到不一样的渠道,而后去点击打开,若是是本地有app,则直接唤起,而后会自动跳入你配置的页面,若是没有,则会跳到你后台配置的下载/引导地址中。

    这时候你就能够从后台统计不一样的渠道来源。

存在问题:

  1. js不是很稳定,配置了path,启动服务后,有时候没法跳转app。
  2. link新增:测试发现后台没有统计,询问后还须要优化,后期开发中。