iOS Universal Links 的使用

通用鏈接(Universal Links)就不詳細(xì)介紹了. 官方文檔已經(jīng)十分詳細(xì): Universal Links 蘋果官網(wǎng)文檔
Universal Links是iOS9推出的一項(xiàng)功能,使你的應(yīng)用可以通過傳統(tǒng)的HTTP鏈接來啟動(dòng)APP或者打開網(wǎng)頁。


一.前期準(zhǔn)備工作

TeamID:XXXXXX (即團(tuán)隊(duì)ID, 在蘋果開發(fā)者網(wǎng)站 Apple Developer -> Member Center ->Membership->Team ID)
Bundle Identifier:xx.xxx.xx

需要生成一個(gè)json文件, 名為apple-app-site-association, 注意: 不需要添加任何后綴 !
內(nèi)容如下:

 {
     "applinks": {
         "apps": [],
         "details": [
             {
                 "appID": "XXXXXX.xx.xxx.xx",
                 "paths": [ "*" ]
             }
         ]
     }
 }

注:
appID: 內(nèi)容為 TeamID+Bundle Identifier , 例 XXXXXX.xx.xxx.xx
paths:設(shè)定你的app支持的路徑列表,只有這些指定的路徑的鏈接,才能被app所處理。星號(hào)的寫法代表了可識(shí)別域名下所有鏈接。

有多種方法可以在apple-app-site-association文件中指定網(wǎng)站路徑。例如,您可以:

使用 * 指定整個(gè)網(wǎng)站
1.包括特定的URL,例如/sub/im/,以指定特定的鏈接
2.附加 * 到特定網(wǎng)址,例如/sub/video/*,指定您網(wǎng)站的某個(gè)部分
3.指定不應(yīng)作為通用鏈接處理的區(qū)域,請?jiān)诼窂阶址拈_頭添加“NOT”(包括后面的空格)

例如

"paths": [ "/sub/im/", "/sub/video/*", "NOT /sub/nor/2021/*"]

二.服務(wù)端

這里需要后臺(tái)的小伙伴配合一下

1.服務(wù)端提供一個(gè)支持https的域名(必須支持https)
2.將上面生成好的json文件(apple-app-site-association)放到上面域名的服務(wù)器根目錄下或者.well-known目錄下


三.iOS客戶端

配置開發(fā)者平臺(tái)

1.登陸蘋果開發(fā)者管理后臺(tái)
2.打開 Member Center --- Certificates, Identifiers & Profiles
3.打開 Identifiers,找到項(xiàng)目對應(yīng)的Identifier并打開
4.勾選Associated Domains選項(xiàng)


開發(fā)者平臺(tái)配置
項(xiàng)目配置

5.打開我們的項(xiàng)目工程,然后繼續(xù)打開我們的工程配置中的Signing&Capabilities
6.點(diǎn)擊左上角的“+Capability”,然后選擇Associated Domains
7.輸入對應(yīng)的Domains 例:你的Universal Links域名為www.test.com, 那么你的Domains的內(nèi)容即為: applinks:test.com

項(xiàng)目配置applinks

  1. 最后一步, 在appDelegate中, 添加如下的代碼
@interface AppDelegate () {
    //1.解決打開未啟動(dòng)的app無法跳轉(zhuǎn)指定頁面的問題
    dispatch_group_t dispatchGroup;
}
@end

@implementation AppDelegate
//當(dāng)用Universal Links啟動(dòng)APP時(shí)就會(huì)調(diào)用下面的方法
- (BOOL)application:(UIApplication *)application continueUserActivity:(NSUserActivity *)userActivity restorationHandler:(void (^)(NSArray<id<UIUserActivityRestoring>> * _Nullable))restorationHandler {    

    if ([userActivity.activityType isEqualToString:NSUserActivityTypeBrowsingWeb]) {
        NSURL *webpageURL = userActivity.webpageURL;
        NSLog(@"====== Universal Links啟動(dòng)APP links:%@======", webpageURL.absoluteString);

        if ([webpageURL.absoluteString containsString:@"test.com"]) {
            //判斷域名是自己的網(wǎng)站,進(jìn)行我們需要的處理
            UINavigationController *nav;
            if (self.tabBarController && self.tabBarController.viewControllers.count) {
                NSInteger index =  [self.tabBarController selectedIndex];
                nav = [self.tabBarController.viewControllers objectAtIndex:index];
            }else {
                nav = nil;
            }

            //4.解決打開未啟動(dòng)的app無法跳轉(zhuǎn)指定頁面的問題
            dispatch_group_notify(dispatchGroup, dispatch_get_main_queue(), ^{
                //跳轉(zhuǎn)CDVViewController
                [[MXKit shareMXKit] pushToUniversalLinksUrlString:webpageURL.absoluteString withNavController:nav withCallback:nil];
            });
        }
    }
    return YES;
}

- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions {
    //2.解決打開未啟動(dòng)的app無法跳轉(zhuǎn)指定頁面的問題
    dispatchGroup = dispatch_group_create();
    dispatch_group_enter(dispatchGroup);

    //doSomething...

    //3.解決打開未啟動(dòng)的app無法跳轉(zhuǎn)指定頁面的問題
    dispatch_group_leave(dispatchGroup);
    return YES;
}

這樣, 我們就實(shí)現(xiàn)了, 點(diǎn)擊www.test.com跳轉(zhuǎn)到app的功能了.

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

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