MobLink是MobTech公司下的一款服务功能。其中包括熟知的ShareSDK,还有SMSSDK、秒验、MobPush、MobLink。官方解释:MobLink是移动场景还原解决方案。说简单些就是分发下载统计的解决方案。其中包括:场景唤醒、多样化跳转、无码邀请、专属连接、来源追溯。javascript
连接:www.mob.com/mobService/…html
好比:须要推广app、活动等,经过不一样的活动页跳转下载或者转入app活动页。一键跳转,统计来源渠道,唤醒,回跳。java
建立应用时,须要认证开发者:公司或者我的,均可以。而后建立应用获取AppKey和AppSecret。c++
须要配置:Team ID、Bundle Id、URL Scheme、下载/引导地址、路由配置。web
配置上述的Universal Link、URL Scheme。objective-c
SDK导入:sql
手动导入,下载demo,把MobLinkPro.framework
,MOBFoundation.framework
导入工程。json
cocoapods:bash
pod 'mob_linksdk_pro'
复制代码
若是搜索不到这个mob_linksdk_pro时:markdown
请先进行: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
复制代码
代码调试:
#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,则直接唤起,而后会自动跳入你配置的页面,若是没有,则会跳到你后台配置的下载/引导地址中。
这时候你就能够从后台统计不一样的渠道来源。