iOS-Snapchat登录集成及注意事项

Snapchat是海外最火的社交App之一,它拥有着大量的年轻用户群体,因此,灵活运用它的SDK,对于出海类社交App来说至关重要。它提供的SDK包括登录(Login Kit),表情贴纸(Bitmoji Kit),创意分享(Creative Kit),本文重点讲解最基础的一环-Snapchat登录

Snapchat官方集成文档
实现整个Snapchat登录功能,主要分以下三个步骤

1. Snapchat控制台的配置

Snapchat控制台地址

Snapchat.png

Snapchat.png

控制台的配置按照相应描述填写即可。
Redirect URL这里建议格式填写为myapp://bundle id/oauth2

Snapchat.png

备注:测试Snapchat的时候,要在Demo Users里添加Snapchat的测试ID,不然会报错。

2. SDK的集成与配置

  • Podfile里文件添加如下
    pod 'SnapSDK'
  • Plist里配置如下:
SCSDKScopes
    
        https://auth.snapchat.com/oauth2/api/user.display_name
        https://auth.snapchat.com/oauth2/api/user.external_id
        https://auth.snapchat.com/oauth2/api/user.bitmoji.avatar
    
SCSDKScopes是用来告诉Snapchat你需要申请用户的什么数据。

是用户的昵称

Snapchat里的display name和user name是两回事,display name是我们理解的昵称,user name是我们理解的唯一ID。我们添加Snapchat好友是用的user name。

是我们拿到的授权ID,后台拿来做唯一标识的。

Snapchat并未提供后台SDK,所以后台是无法判断前端给的external id是否真实存在。因此,如果App有相应业务场景的话,一定要做好接口加密,防止批量被刷。

很好理解,即是用户头像。
另外,Plist里还需加入以下内容

SCSDKClientId
    控制台申请的客户端ID
    SCSDKRedirectUrl
    控制台填写的回调URL
LSApplicationQueriesSchemes
    
        snapchat
        bitmoji-sdk
        itms-apps
    
  • Info里配置如下:
    TARGETS-Info-URL Types
    Info.png

    Identifier填写App名字即可
    URL Schemes填写bundle ID即可
Identifier这里要和RedirectUrl进行对应,如果你的RedirectUrl格式是myapp://bundle id/oauth2 那么Identifier 就填写myapp。URL Schemes那里要填写bundle id。

3.代码配置

AppDelegate中

- (BOOL)application:(UIApplication *)app openURL:(NSURL *)url options:(NSDictionary *)options {
    
    BOOL handled = [SCSDKLoginClient application:app openURL:url options:options];
    if (handled) {
        NSLog(@"是Snapchat登录");
        //展示HUD
        [PCHUD showHudWith:@""];
    }else{
        NSLog(@"不是Snapchat登录");
    }
    
    return handled;
}

LoginViewController

- (void)snapChatLogin {
    [SCSDKLoginClient loginFromViewController:self completion:^(BOOL success, NSError * _Nullable error) {
        [PCHUD removeHudWith:@""];
        if (error) {
            NSLog(@"授权失败error=%@",error);
        }
        if (success) {
            NSLog(@"授权成功");
        ];
            [self fetchUserData];
        }
    }];
}
- (void)fetchUserData {
    [PCHUD showHudWith:@""];
    //这里是GraphQL 获取需要的用户信息,可以根据需要获取
    NSString *queryString = @"{me{bitmoji{avatar,selfie},displayName,externalId}}";
    [SCSDKLoginClient fetchUserDataWithQuery:queryString variables:nil success:^(NSDictionary * _Nullable resources) {
        NSDictionary *paramDict = resources[@"data"][@"me"];
        NSLog(@"用户信息resources=%@",paramDict);
        //把字段信息传给后台
        [self doLoginLogical:paramDict];
        
    } failure:^(NSError * _Nullable error, BOOL isUserLoggedOut) {
        NSLog(@"用户获取信息授权失败error=%@",error);
        [PCHUD removeHudWith:@""];
    }];
}

你可能感兴趣的:(iOS-Snapchat登录集成及注意事项)