目前分享功能支持新浪微博分享、QQ分享、微信分享,分享功能首先需要到各开放平台申请帐号,参考 文档

新浪微博分享

添加依赖库及资源

依赖库 系统库 依赖资源
liblibShare.a、libSinaShare.a、libWeiboSDK.a ImageIO.framework、libsqlite3.0.tbd WeiboSDK.bundle

工程配置

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

新浪微博分享 - 图1

注意 SDK 3.2.0+ 必须按照下图填写

新浪微博分享 - 图2

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

新浪微博分享 - 图3

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

新浪微博分享 - 图4

注意 SDK 3.2.0+ 必须按照下图填写

新浪微博分享 - 图5

配置Associated Domains(域名)

新浪微博分享 - 图6

填写通用链接域名

新浪微博分享 - 图7

QQ分享

添加依赖库及资源

依赖库 系统库 依赖资源
liblibShare.a、libQQShare.a、TencentOpenAPI.framework

工程配置

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

新浪微博分享 - 图8

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

新浪微博分享 - 图9

注意 SDK 3.2.0+ 必须按照下图填写

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

新浪微博分享 - 图10

  1. 配置Associated Domains(域名)

新浪微博分享 - 图11

填写通用链接域名

新浪微博分享 - 图12

微信分享

添加依赖库及资源

依赖库 系统库 依赖资源
liblibShare.a、libweixinShare.a、libWeChatSDK.a libsqlite3.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],如下图所示

新浪微博分享 - 图13

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

新浪微博分享 - 图14

3.配置Associated Domains(域名)

新浪微博分享 - 图15

填写通用链接域名

新浪微博分享 - 图16

4.在info.plist root 节点添加UniversalLinks字段,值和您在微信开放平台配置的一致,参考如下:(SDK 3.2.0版本以后 此项已废弃,仅保留字段,配置参数已经位置如步骤5所示)

新浪微博分享 - 图17

5.在 info.plist 添加 weixin(3.2.0 以前为weixinoauth) 项,填写微信 appidappSecret, UniversalLinks,值和您在微信开放平台配置的一致,参考如下:

新浪微博分享 - 图18

6.在工程的 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. }

注意 :所有分享都需要实现如下方法

在 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. }