IOS_通用链接Universal Link介绍及使用

本文主要内容参考此文章,主要是为了记录


产品需求

用户从qq/微信分享出去的H5页面,当点击H5页面的某个按钮时,要实现如下功能:

1.当用户未安装App时,跳转到AppStore页面引导用户下载

2.当用户已安装App时,唤醒App并跳转到App里面的某一个指定页面

传统的url schema实现方式存在两个弊端,一是跳转的时候会有一个提示框:“是否打开XXX”,用户体验不好,二是微信屏蔽了URL Scheme,必须是在微信的白名单里面才可跳转,也就意味着用户在微信里面是无法一键直达App的。这对于大多数公司来讲,是难以承受的。而通用链接Universal Link正是可以解决上述问题的技术手段。

通用链接介绍及优点

通用链接介绍及优点预留位置

通用链接具体实施步骤

这里可以分两种实现方式,第一种是自己去配置通用链接,第二种是通过一些第三方SDK来实现此功能。

①自己配置通用链接
iOS的UniversalLink开发总结 不建议问题太多

②用第三方SDK去集成配置(魔窗,LinkedME等)
下面以魔窗为例,讲解如何配置。魔窗iOS集成文档

用魔窗的话iOS端只需要做三部分操作,分别是魔窗后台配置部分,Xcode配置部分,代码实现部分。下面将详细描述步骤。

魔窗后台配置部分

①注册一个魔窗账号 魔窗注册
②账号注册完毕后,登录魔窗点击右上角新增产品然后选择App。

IOS_通用链接Universal Link介绍及使用_第1张图片
_CLAY_.png

IOS_通用链接Universal Link介绍及使用_第2张图片
_CLAY_.png

③要填写的信息分为三部分,分别是产品信息,App信息,魔窗位信息。魔窗位信息可以不填。
IOS_通用链接Universal Link介绍及使用_第3张图片
_CLAY_.png

④想要使用深度链接,还需要配置魔窗的mlink服务,如下图
IOS_通用链接Universal Link介绍及使用_第4张图片
_CLAY_.png

至此,魔窗的所有配置均已做完。

小结:魔窗的配置是为了获得五个关键参数,以供后面配置使用。分别是URL Scheme,魔窗App key,魔窗mLink key 魔窗域名 魔窗短连接。
Xcode配置部分

Xcode这边配置非常容易,就两步即可。

①配置URL Scheme 这里的identifier可填可不填没影响,URL Schemes这里填在魔窗后台配置时,你写的URL Scheme,魔窗跟Xcode这里二者必须保持一致

②applinks配置 这里的Domains一定要填你之前在魔窗配置后获得的那个魔窗域名,这里要保证不能出差错,否则无法完成跳转


IOS_通用链接Universal Link介绍及使用_第5张图片
_CLAY_.png

Xcode的配置到这里就完成了。

代码实现部分

①集成魔窗sdk,手动和cocopods两种方式,手动请参考魔窗文档,下面只讲cocopods集成

pod 'MagicWindowSDK'

pod install

记住不要pod update,因为魔窗sdk自己集成了微信分享,非常容易跟shareSDK 友盟分享SDK冲突。

②Appdelegate中实现注册魔窗

//引入魔窗的SDK头文件
#import "MWApi.h"

- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions {
    
    [MWApi registerMLinkDefaultHandler:^(NSURL * _Nonnull url, NSDictionary * _Nullable params) {
        NSLog(@"%@",params);
        
        [self jumpToControllerWith:params];
        
    }];
    
    [MWApi registerMLinkHandlerWithKey:@"iOSXZNSGoddessZhunleKey" handler:^(NSURL *url, NSDictionary *params) {
        //自行处理跳转逻辑,示例如下:
        NSLog(@"%@",params);
        
        [self jumpToControllerWith:params];
        
    }];
}

- (void)jumpToControllerWith:(NSDictionary *)userInfoDic {
    
    UIViewController *rootViewController = [UIApplication sharedApplication].keyWindow.rootViewController;
    UIViewController *currentVC = [self getCurrentVCFrom:rootViewController];//首先获取当前所在的控制器
    
    if ([[userInfoDic objectForKey:@"xxx"] isEqualToString:@"xxx"]) {
        //根据需求可以在这里判断页面的跳转
    } else {
        //根据需求可以在这里判断页面的跳转
    }
}

- (UIViewController *)getCurrentVCFrom:(UIViewController *)rootVC {
    UIViewController *currentVC;
    if ([rootVC presentedViewController]) {
        // 视图是被presented出来的
        rootVC = [rootVC presentedViewController];
    }
    if ([rootVC isKindOfClass:[UITabBarController class]]) {
        // 根视图为UITabBarController
        currentVC = [self getCurrentVCFrom:[(UITabBarController *)rootVC selectedViewController]];
    } else if ([rootVC isKindOfClass:[UINavigationController class]]){
        // 根视图为UINavigationController
        currentVC = [self getCurrentVCFrom:[(UINavigationController *)rootVC visibleViewController]];
    } else {
        // 根视图为非导航类
        currentVC = rootVC;
    }
    return currentVC;
}

你可能感兴趣的:(IOS_通用链接Universal Link介绍及使用)