簡介:
URL Scheme就是一個可以讓app相互之間可以跳轉的對外接口。通過給APP定義一個唯一的URL路徑來從外部快速的打開這個指定的APP,每個app的URL Scheme都是不一樣的,如果存在一樣的URL Scheme,那么系統就會響應先安裝那個app的URL Scheme,因為后安裝的app的URL Scheme被覆蓋掉了,是不能被調用的。
應用:
- 第三方分享的SDK就是通過這種方式來實現分享的,我們將需要分享的數據傳遞給SDK,SDK通過OpenURL來打開第三方應用傳遞數據,返回時SDK來處理OpenUrl的參數,實現查看分享的回調。
- 從瀏覽器中某一頁面的點擊事件可以打開對應客戶端的某一個界面,就是通過協議 URL Scheme:// + 參數 來完成喚醒跳轉客戶端界面的。
- 調用微信、支付寶等客戶端完成支付的功能。
- 三方應用調用系統所帶的地圖軟件。
示例:
接下來就以我之前寫的UIActivityViewController系統原生分享-仿簡書分享和iOS開源小項目-WSL兩個Demo為例,讓我們看下怎么可以讓UIActivityViewController系統原生分享-仿簡書分享喚起iOS開源小項目-WSL並進行通信、分享:也就是說讓 WSL 像微信、QQ、新浪一樣支持第三方社交分享。
一、配置WSL的應用信息,添加Url Scheme
要跳轉到別人的app,就要知道別人的app的跳轉協議是什么,需要傳入什么參數,如果我們希望別人打開我們的app,也需要在info.plist中配置跳轉協議,然后再重寫AppDelegate中的 openUrl方法來處理邏輯參數。
-
給 WSL 添加Url Scheme
-
重寫WSL中AppDelegate中的openUrl方法,當WSL被喚起時會執行openUrl方法,我們可以在方法里根據傳入的參數的做出處理。如果只想允許在特定情況下才能被喚起,比如說分享,就可以對傳入的openUrl加以驗證,符合要求return YES ,否則返回NO。
/**
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 之后
三方喚起本程序后執行的方法
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系統原生分享中添加事件,通過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系統原生分享,同時傳遞數據處理的結果。相當於WSL回調喚起UIActivityViewController系統原生分享,過程同一、二步。
- 給UIActivityViewController系統原生分享 也添加Url Scheme,便於從WSL返回主應用UIActivityViewController系統原生分享。
- 重寫UIActivityViewController系統原生分享中AppDelegate中的openUrl方法,在返回UIActivityViewController系統原生分享應用時根據從WSL返回的數據處理結果做出反應。
以上就是通過Url Scheme實現APP間相互跳轉、傳遞數據、通信、分享功能的過程。
經過以上操作內容,小伙伴們是不是對其中的步驟有種似曾相識的感覺呢?沒錯,集成的第三方分享SDK就是通過這種方式來實現分享的,只不過它們把數據、方法都封裝到了SDK中。
四、項目結構
Url Scheme實現APP間通信、分享
注:本文著作權歸作者,由demo大師代發,拒絕轉載,轉載需要作者授權