iOS-MobLink集成流程

简介:

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

应用场景:

比如:需要推广app、活动等,通过不同的活动页跳转下载或者转入app活动页。一键跳转,统计来源渠道,唤醒,回跳。

集成流程:

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

流程分解:

  1. 创建应用时,需要认证开发者:公司或者个人,都可以。然后创建应用获取AppKey和AppSecret。

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

作为一个开发者,有一个学习的氛围跟一个交流圈子特别重要,这是一个我的iOS交流群:834688868,不管你是大牛还是小白都欢迎入驻 ,分享BAT,阿里面试题、面试经验,讨论技术, 大家一起交流学习成长!

#### **需要注意**

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

    SDK导入:

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

    2. cocoapods:

      pod 'mob_linksdk_pro'
      
      

      如果搜索不到这个mob_linksdk_pro时:

      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
      
      
  2. 代码调试:

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

  3. web js配置

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

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

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

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

这时候你就可以从后台统计不同的渠道来源。

存在问题:

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

作为一个开发者,有一个学习的氛围跟一个交流圈子特别重要,这是一个我的iOS交流群:834688868,不管你是大牛还是小白都欢迎入驻 ,分享BAT,阿里面试题、面试经验,讨论技术, 大家一起交流学习成长!

以下资料在群文件可自行下载!

作者:宇轩Simid
链接:https://www.jianshu.com/p/b29d77a2a5a3

posted @ 2020-11-16 22:24  iOS开发专栏  阅读(251)  评论(0编辑  收藏  举报