【11】Apple第三方登陸

一、通用鏈接配置

1、在開發(fā)者中心進行配置:找到對應的App ID,在 Application Services 列表里將 Associated Domains 更改為 Enabled

2、打開工程配置 Capabilities 選項卡中的 Associated Domains 開關,在其中的 Domains 中填入域名,必須以"applinks:"為前綴;

例:applinks:test.universallinks.com          ---- 注意這里不需要寫HTTPS

3、創(chuàng)建JSON 數(shù)據(jù)格式的名為apple-app-site-association 的文件(名字必須,不能添加后綴),內容為你的應用需關聯(lián)的所有路徑,建議用通配符*號,格式示例:

{
    "applinks": {
        "apps": [],
        "details": [
            {
                "appID": "9JA89QQLNQ.com.apple.wwdc",
                "paths": [ "/wwdc/news/", "/videos/wwdc/2015/*"]
            },
            {
                "appID": "ABCD1234.com.apple.wwdc",
                "paths": [ "*" ]
            }
        ]
    }
}
注:iOS 9.3.1或更高版本中運行的應用程序,apple-app-site-association 的文件大小必須≤128 KB(未驗證)

4、上傳apple-app-site-association 文件至你的網(wǎng)站服務器(需支持HTTPS 協(xié)議),并將其放置網(wǎng)站根目錄或 .well-known 文件夾下。

5、在 AppDelegate 的 - (BOOL)application: continueUserActivity: restorationHandler: 方法中處理通用鏈接。

- (BOOL)application:(nonnull UIApplication *)application
continueUserActivity:(nonnull NSUserActivity *)userActivity
 restorationHandler:(nonnull void (^)(NSArray * __nullable))restorationHandler {
    if ([userActivity.activityType isEqualToString:NSUserActivityTypeBrowsingWeb]) {
        NSURL *webpageURL = userActivity.webpageURL;
        NSString *host = webpageURL.host;
        if ([host isEqualToString:@"test.universallinks.com"]) {
            // TODO:處理應用內跳轉邏輯
        }else {
            [[UIApplication sharedApplication]openURL:webpageURL];
        }
        return YES;
    }
    return NO;
}

6、驗證是否配置成功

在你的系統(tǒng)備忘錄中寫你配置的域名,點擊打開,拉到最頂上,會出現(xiàn)你的APP圖標則代表配置成功;注:頁面可能會顯示404,可不予理會,拉到最頂上有APP圖標便可!

二、客戶端配置

基礎證書配置不再敘述,僅記錄配置第三方登陸;

具體可參考此文章:https://www.wangquanwei.com/572.html

補充:在創(chuàng)建秘鑰之前,需要先創(chuàng)建一個Apple登陸的serviceID;

1、創(chuàng)建services IDs

image.png

剩下的步驟一直確定便可;

三、服務端驗證

1、為了方便驗證,我這里先自己作為服務器進行驗證,向https://appleid.apple.com/auth/token請求需要的幾個參數(shù):

client_id:傳遞App的BundleID即可
code:傳遞客戶端獲取到的authorizationCode
grant_type:傳遞authorization_code固定字符串即可
client_secret:可利用以下ruby腳本生成

編寫以下腳本,后綴為rb,再從終端執(zhí)行 ruby 文件名.rb,生成client_secret字符串;

ruby腳本:

require "jwt"
key_file = "xxxxx.p8"   #從Developer Center后臺下載的key(p8后綴的文件)
team_id = "xxxxxx"      #開發(fā)者賬號的teamID
client_id = "com.xxx.xxx"     #應用的BundleID
key_id = "xxxxxx"      #從Developer Center后臺key_id
validity_period = 180  #有效期

private_key = OpenSSL::PKey::EC.new IO.read key_file

token = JWT.encode(
    {
        iss: team_id,
        iat: Time.now.to_i,
        exp: Time.now.to_i + 86400 * validity_period,
        aud: "https://appleid.apple.com",
        sub: client_id
    },
    private_key,
    "ES256",
    header_fields=
    {
        kid: key_id
    }
)
puts token
?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
【社區(qū)內容提示】社區(qū)部分內容疑似由AI輔助生成,瀏覽時請結合常識與多方信息審慎甄別。
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發(fā)布,文章內容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務。

友情鏈接更多精彩內容