支持新浪微博登录、QQ登录、微信登录、及苹果授权登录,然后需要到各开放平台申请帐号,查看该文档

新浪微博登录

添加依赖库及资源

依赖库系统库依赖资源
liblibOauth.a、libSinaWBOauth.a、liblWeiboSDK.aImageIO.framework、libsqlite3.0.tbdWeiboSDK.bundle

工程配置

1.在 info.plist 中添加 sinweibo 字段,填入自己帐号的信息,如下图

Oauth(登录鉴权) - 图1

2.在工程的 info -> URL types 中添加配置,identifier 填写com.weibo,URL Schemes 填写wb[后面填写appkey],如下图所示

Oauth(登录鉴权) - 图2

3.在 info.plist 添加 Schemes 白名单

Oauth(登录鉴权) - 图3

QQ登录

添加依赖库及资源

依赖库系统库依赖资源
liblibOauth.a、libQQOauth.a、TencentOpenAPI.frameworkTencentOpenApi_IOS_Bundle.bundle

工程配置

1.在工程的 info -> URL types 中添加配置,identifier 填写tencentopenapi,URL Schemes 填写tencent[后面填写appid],如下图所示

Oauth(登录鉴权) - 图4

2.在 info.plist 添加 Schemes 白名单

Oauth(登录鉴权) - 图5

微信登录

添加依赖库及资源

依赖库系统库依赖资源
liblibOauth.a、libWXOauth.a、libWeChatSDK.alibsqlite3.0.tbd、libz.tbd、CoreTelephony.framework、SystemConfiguration.framework

注意:SDK 中的

  • libWeChatSDK_pay.a 为带支付功能的微信SDK,支持微信分享、微信支付及微信授权登录功能
  • libWeChatSDK.a 为不带支付功能的SDK,仅支持微信分享和授权登录,不使用支付功能请添加此库,避免审核被拒
  • 不要同时添加到工程避免冲突

工程配置

1.在工程的 info -> URL types 中添加配置,identifier 填写weixin,URL Schemes 填写wx[后面填写appid],如下图所示

Oauth(登录鉴权) - 图6

2.在 info.plist 添加 Schemes 白名单

Oauth(登录鉴权) - 图7

3.在info.plist root 节点添加UniversalLinks字段,值和您在微信开放平台配置的一致,参考如下:

Oauth(登录鉴权) - 图8

4.在工程的 AppDelegate.m 系统通用链接回调方法中调用框架方法如下:

  1. - (BOOL)application:(UIApplication *)application continueUserActivity:(NSUserActivity *)userActivity restorationHandler:(void(^)(NSArray<id<UIUserActivityRestoring>> * __nullable restorableObjects))restorationHandler {
  2. [PDRCore handleSysEvent:PDRCoreSysEventContinueUserActivity withObject:userActivity];
  3. restorationHandler(nil);
  4. return YES;
  5. }

苹果登录

添加依赖库及资源

依赖库系统库依赖资源
liblibOauth.a、libAppleOauth.aAuthenticationServices.framework

苹果授权登录使用 文档

注意 :除苹果授权登录外,都需要实现如下方法

在 AppDelegate.m 文件的系统回调方法中调用框架的方法如下

  1. - (BOOL)application:(UIApplication *)application handleOpenURL:(NSURL *)url
  2. {
  3. [PDRCore handleSysEvent:PDRCoreSysEventOpenURL withObject:url];
  4. return YES;
  5. }
  6. - (BOOL)application:(UIApplication *)application openURL:(nonnull NSURL *)url options:(nonnull NSDictionary<UIApplicationOpenURLOptionsKey,id> *)options {
  7. [PDRCore handleSysEvent:PDRCoreSysEventOpenURLWithOptions withObject:@[url,options]];
  8. return YES;
  9. }

发现错误?想参与编辑?在 GitHub 上编辑此页面!