簡介:
URL Scheme就是一個可以讓app相互之間可以跳轉的對外接口挽封。通過給APP定義一個唯一的URL路徑來從外部快速的打開這個指定的APP,每個app的URL Scheme都是不一樣的辅愿,如果存在一樣的URL Scheme,那么系統(tǒng)就會響應先安裝那個app的URL Scheme阔蛉,因為后安裝的app的URL Scheme被覆蓋掉了癞埠,是不能被調用的。
應用:
- 第三方分享的SDK就是通過這種方式來實現分享的苗踪,我們將需要分享的數據傳遞給SDK通铲,SDK通過OpenURL來打開第三方應用傳遞數據,返回時SDK來處理OpenUrl的參數,實現查看分享的回調磨澡。
- 從瀏覽器中某一頁面的點擊事件可以打開對應客戶端的某一個界面质和,就是通過協議 URL Scheme:// + 參數 來完成喚醒跳轉客戶端界面的。
- 調用微信饲宿、支付寶等客戶端完成支付的功能。
- 三方應用調用系統(tǒng)所帶的地圖軟件仗阅。
示例:
接下來就以我之前寫的UIActivityViewController系統(tǒng)原生分享-仿簡書分享和iOS開源小項目-WSL兩個Demo為例国夜,讓我們看下怎么可以讓UIActivityViewController系統(tǒng)原生分享-仿簡書分享喚起iOS開源小項目-WSL并進行通信车吹、分享:也就是說讓 WSL 像微信、QQ窄驹、新浪一樣支持第三方社交分享。
一抗斤、配置WSL的應用信息丈咐,添加Url Scheme
要跳轉到別人的app,就要知道別人的app的跳轉協議是什么扯罐,需要傳入什么參數歹河,如果我們希望別人打開我們的app花吟,也需要在info.plist中配置跳轉協議,然后再重寫AppDelegate中的 openUrl方法來處理邏輯參數衅澈。
-
給 WSL 添加Url Scheme
添加URL Scheme.png 重寫WSL中AppDelegate中的openUrl方法今布,當WSL被喚起時會執(zhí)行openUrl方法拭抬,我們可以在方法里根據傳入的參數的做出處理侵蒙。如果只想允許在特定情況下才能被喚起,比如說分享算凿,就可以對傳入的openUrl加以驗證犁功,符合要求return YES ,否則返回NO浸卦。
//第三方應用打開本應用啟動
- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions {
// Override point for customization after application launch.
//第三方應用打開本應用啟動
if(launchOptions[UIApplicationLaunchOptionsURLKey] != nil){
[self application:application handleOpenURL:launchOptions[UIApplicationLaunchOptionsURLKey]];
}
return YES;
}
/**
iOS 9.0 以下 程序在運行過程中才能調用
*/
- (BOOL)application:(UIApplication *)application handleOpenURL:(NSURL *)url{
NSString *text = [[url host] stringByReplacingPercentEscapesUsingEncoding:NSUTF8StringEncoding];
NSLog(@"URL scheme:%@", [url scheme]);
NSLog(@"URL query: %@", [url query]);
return YES;
}
/**
iOS 9.0 之后 程序在運行過程中才能調用
三方喚起本程序后執(zhí)行的方法
return YES 表示允許喚起本程序
*/
- (BOOL)application:(UIApplication *)app openURL:(NSURL *)url options:(NSDictionary<UIApplicationOpenURLOptionsKey, id> *)options{
NSLog(@"URL scheme:%@", [url scheme]);
//參數
NSLog(@"URL host:%@", [url host]);
UIAlertView *alertView=[[UIAlertView alloc] initWithTitle:@"分享" message:[url host] delegate:self cancelButtonTitle:nil otherButtonTitles:@"分享完成", nil];
[alertView show];
return YES;
}
- (void)alertView:(UIAlertView *)alertView clickedButtonAtIndex:(NSInteger)buttonIndex{
//返回URL scheme = wsl123456的主應用
NSURL * url = [NSURL URLWithString:@"wsl123456://success"];
[[UIApplication sharedApplication] openURL:url options:nil completionHandler:^(BOOL success) {
}];
}
- 通過瀏覽器打開喚起WSL镐躲,測試一下,輸入的地址是" WSLAPP://wslmeiksjkfdfkfkfhskfhskfhskj "(Url Scheme://+ 參數字符串)撒穷,參數可以為空裆熙。
二、在UIActivityViewController系統(tǒng)原生分享中添加事件蛤奥,通過Url Scheme來喚起WSL僚稿,并傳參
- (IBAction)shareToWSL:(id)sender {
//不帶參數
NSString * wslUrlScheme = @"WSLAPP://";
//如果參數含有特殊字符或漢字,需要轉碼缅刽,否則這個URL不合法蠢络,就會喚起失敗刹孔;參數字符串的格式可以自定義,只要便于自己到時候解析就行
NSString * parameterStr = [@"name=wsl&weight=保密" stringByAddingPercentEscapesUsingEncoding:NSUTF8StringEncoding];
//不帶參數
// NSURL * url = [NSURL URLWithString:wslScheme];
//帶參數
//WSLAPP://name=wsl&weight=保密
NSURL * url = [NSURL URLWithString:[wslUrlScheme stringByAppendingString:parameterStr]];
//iOS 10以下
// [[UIApplication sharedApplication] openURL:url];
//iOS 10以上
[[UIApplication sharedApplication] openURL:url options:nil completionHandler:^(BOOL success) {
}];
}
三卦睹、喚起WSL之后需要做的處理
喚起WSL之后,WSL根據傳入的參數進行界面數據的處理兢交,處理完成之后笼痹,我們需要自動返回主應用UIActivityViewController系統(tǒng)原生分享,同時傳遞數據處理的結果晴裹。相當于WSL回調喚起UIActivityViewController系統(tǒng)原生分享救赐,過程同一、二步经磅。
- 給UIActivityViewController系統(tǒng)原生分享 也添加Url Scheme预厌,便于從WSL返回主應用UIActivityViewController系統(tǒng)原生分享。
- 重寫UIActivityViewController系統(tǒng)原生分享中AppDelegate中的openUrl方法苗沧,在返回UIActivityViewController系統(tǒng)原生分享應用時根據從WSL返回的數據處理結果做出反應炭晒。
以上就是通過Url Scheme實現APP間相互跳轉、傳遞數據识樱、通信震束、分享功能的過程。
經過以上操作內容驴一,小伙伴們是不是對其中的步驟有種似曾相識的感覺呢灶壶?沒錯,集成的第三方分享SDK就是通過這種方式來實現分享的胸懈,只不過它們把數據、方法都封裝到了SDK中趣钱。
iOS 9 通用鏈接(Universal Links) 通過傳統(tǒng)的HTTP鏈接來啟動APP首有。