AppDelegate减负之常用三方封装 - 友盟分享 / 三方登录篇
Posted 一切都是最好的安排
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了AppDelegate减负之常用三方封装 - 友盟分享 / 三方登录篇相关的知识,希望对你有一定的参考价值。
之前完成了 AppDelegate减负之常用三方封装 - 友盟推送篇:
http://www.cnblogs.com/zhouxihi/p/7113511.html
今天接着来完成 - 友盟分享和三方登录篇
首先去友盟上面下载SDK, 一般就新浪/微信/QQ 我们都选择精简版
把下载好的SDK添加到项目,
按照开发文档添加libsqlite3.0.tbd到Linked Frameworks,
在Build Settings -> Linking -> Other Linker Flags 添加-ObjC
然后我们就可以开始了
首先跟之前友盟推送部分一样, 创建一个AppDelegate+UMSocial.h类别
在头文件中导入:
#import <UMSocialCore/UMSocialCore.h> #import <UShareUI/UShareUI.h>
接下来我们先在头文件中写初始化方法
通用初始化方法:
/** 初始化友盟分享 (推荐方法, 在AppKey.h中配置各项秘钥) */ - (void)zx_configureUMSocialSDK;
单一只初始化友盟SDK
/** 单一只初始化友盟分享, 此方法不会去配置微信/QQ/新浪等分享组件 @param appKey 秘钥 */ - (void)zx_configuerUMSocialSDKWithAppKey:(NSString *)appKey;
下面先写分享部分的方法
配置微信分享的方法
/** 单一只配置微信分享 (推荐使用- (void)zx_configureUMSocialSDK;方法统一配置) @param appKey Wechat appKey @param appSecret Wechat appSecret @param redirectURL Wechat redirect URL */ - (void)zx_configureWechatShareWithAppKey:(NSString *)appKey appSecret:(NSString *)appSecret redirectURL:(NSString *)redirectURL;
配置QQ分享的方法
/** 单一只配置QQ分享 (推荐使用- (void)zx_configureUMSocialSDK;方法统一配置) @param appKey QQ appKey @param appSecret QQ appSecrect (一般传nil) @param redirectURL QQ redirect URL */ - (void)zx_configureQQShareWithAppKey:(NSString *)appKey appSecret:(NSString *)appSecret redirectURL:(NSString *)redirectURL;
配置新浪分享的方法
/** 单一只配置新浪分享 (推荐使用- (void)zx_configureUMSocialSDK;方法统一配置) @param appKey Sina appKey @param appSecrect Sina app @param redirectURL Sina redirect URL */ - (void)zx_configureSinaShareWithAppKey:(NSString *)appKey appSecrect:(NSString *)appSecrect redirectURL:(NSString *)redirectURL;
下面是实际的分享方法
先定义一个回调方法
typedef void(^UMSocialCallBack)(BOOL success, id responseObject, NSError *error);
分享文本
/** 分享文本 @param text 要分享的文本 @param currentVC 调用分享方法的控制面板 @param callback 回调方法 */ - (void)zx_shareTextWithString:(NSString *)text currentViewController:(UIViewController *)currentVC callback:(UMSocialCallBack)callback;
分享图片
/** 分享图片 @param image 要分享的图片 @param thumImage 缩略图 @param currentVC 调用分享方法的控制面板 @param callback 回调方法 */ - (void)zx_shareImageWithImage:(UIImage *)image thumImage:(UIImage *)thumImage currentViewController:(UIViewController *)currentVC callback:(UMSocialCallBack)callback;
分享图文
/** 分享图文 @param text 要分享的文字 @param image 要分享的图片 @param thumImage 缩略图 @param currentVC 调用分享方法的控制面板 @param callback 回调方法 */ - (void)zx_shareTextWithString:(NSString *)text andImage:(UIImage *)image thumImage:(UIImage *)thumImage currentViewController:(UIViewController *)currentVC callback:(UMSocialCallBack)callback;
分享网页
/** 分享网页 @param url 要分享的网页地址 @param title 标题 @param description 描述 @param thumImage 缩略图 @param currentVC 调用分享方法的控制面板 @param callback 回调方法 */ - (void)zx_shareWebPageWithURLStr:(NSString *)url title:(NSString *)title description:(NSString *)description thumImage:(UIImage *)thumImage currentViewController:(UIViewController *)currentVC callback:(UMSocialCallBack)callback;
分享音乐
/** 分享音乐 @param musicURL 音乐的url @param title 标题 @param description 描述 @param thumImage 缩略图 @param currentVC 调用分享方法的控制面板 @param callback 回调方法 */ - (void)zx_shareMusicWithURLStr:(NSString *)musicURL title:(NSString *)title description:(NSString *)description thumImage:(UIImage *)thumImage currentViewController:(UIViewController *)currentVC callback:(UMSocialCallBack)callback;
分享视频
/** 分享视频 @param videoURL 视频的url @param title 标题 @param description 描述 @param thumImage 缩略图 @param currentVC 调用分享方法的控制面板 @param callback 回调方法 */ - (void)zx_shareVideoWithURLStr:(NSString *)videoURL title:(NSString *)title description:(NSString *)description thumImage:(UIImage *)thumImage currentViewController:(UIViewController *)currentVC callback:(UMSocialCallBack)callback;
分享微信小程序
/** 分享微信小程序 @param programPath 小程序页面路径 @param webPageURL 兼容网页地址 @param userName 用户名 @param title 小程序标题 @param description 小程序内容描述 @param thumImage 缩略图 @param currentVC 调用分享方法的控制面板 @param callback 回调方法 */ - (void)zx_WeichatMiniProgramWithPath:(NSString *)programPath webPageURL:(NSString *)webPageURL userName:(NSString *)userName title:(NSString *)title description:(NSString *)description thumImage:(UIImage *)thumImage currentViewController:(UIViewController *)currentVC callback:(UMSocialCallBack)callback;
接下来我们写拉取三方登录授权的方法
拉取新浪登录授权
/** 拉取新浪登录授权信息 @param currentViewController 调用登录的当前控制面板 @param callback 回调方法 */ - (void)zx_getAuthInfoFromSinaWithCurrentViewController:(UIViewController *)currentViewController CallBack:(UMSocialCallBack)callback;
拉取微信登录授权
/** 拉取微信登录授权信息 @param currentViewController 调用登录的当前控制面板 @param callback 回调方法 */ - (void)zx_getAuthInfoFromWechatWithCurrentViewController:(UIViewController *)currentViewController CallBack:(UMSocialCallBack)callback;
拉取QQ登录授权
/** 拉取QQ登录授权信息 @param currentViewController 调用登录的当前控制面板 @param callback 回调方法 */ - (void)zx_getAuthInfoFromQQWithCurrentViewController:(UIViewController *)currentViewController CallBack:(UMSocialCallBack)callback;
下面是实现方法:
// // AppDelegate+UMSocial.m // ThirdPartDemo // // Created by Jackey on 2017/7/4. // Copyright © 2017年 com.zhouxi. All rights reserved. // #import "AppDelegate+UMSocial.h" #import "AppKey.h" @implementation AppDelegate (UMSocial) #pragma mark - 配置UMSocial SDK /** 初始化友盟分享 (推荐方法, 在AppKey.h中配置各项秘钥) */ - (void)zx_configureUMSocialSDK { // 配置友盟秘钥 [self zx_configuerUMSocialSDKWithAppKey:UMSocialAppKey]; // 配置Wechat if ([WechatAppKey length] > 0) { NSLog(@"配置微信"); [self zx_configureWechatShareWithAppKey:WechatAppKey appSecret:WechatAppSecret redirectURL:WeChatRedirectURL]; } // 配置QQ if ([QQAppKey length] > 0) { NSLog(@"配置QQ"); [self zx_configureQQShareWithAppKey:QQAppKey appSecret:QQAppSecrect redirectURL:QQRedirectURL]; } // 配置Sina if ([SinaAppKey length] > 0) { NSLog(@"配置新浪"); [self zx_configureSinaShareWithAppKey:SinaAppKey appSecrect:SinaAppSecrect redirectURL:SinaRedirectURL]; } } /** 单一只初始化友盟分享, 此方法不会去配置微信/QQ/新浪等分享组件 @param appKey 秘钥 */ - (void)zx_configuerUMSocialSDKWithAppKey:(NSString *)appKey { // 打开调试日志 [[UMSocialManager defaultManager] openLog:YES]; // 设置友盟appKey [[UMSocialManager defaultManager] setUmSocialAppkey:UMSocialAppKey]; } /** 单一只配置微信分享 (推荐使用- (void)zx_configureUMSocialSDK;方法统一配置) @param appKey Wechat appKey @param appSecret Wechat appSecret @param redirectURL Wechat redirect URL */ - (void)zx_configureWechatShareWithAppKey:(NSString *)appKey appSecret:(NSString *)appSecret redirectURL:(NSString *)redirectURL { [[UMSocialManager defaultManager] setPlaform:UMSocialPlatformType_WechatSession appKey:appKey appSecret:appSecret redirectURL:redirectURL]; } /** 单一只配置QQ分享 (推荐使用- (void)zx_configureUMSocialSDK;方法统一配置) @param appKey QQ appKey @param appSecret QQ appSecrect (一般传nil) @param redirectURL QQ redirect URL */ - (void)zx_configureQQShareWithAppKey:(NSString *)appKey appSecret:(NSString *)appSecret redirectURL:(NSString *)redirectURL { [[UMSocialManager defaultManager] setPlaform:UMSocialPlatformType_QQ appKey:appKey appSecret:appSecret redirectURL:redirectURL]; } /** 单一只配置Sina分享 (推荐使用- (void)zx_configureUMSocialSDK;方法统一配置) @param appKey Sina appKey @param appSecrect Sina app @param redirectURL Sina redirect URL */ - (void)zx_configureSinaShareWithAppKey:(NSString *)appKey appSecrect:(NSString *)appSecrect redirectURL:(NSString *)redirectURL { [[UMSocialManager defaultManager] setPlaform:UMSocialPlatformType_Sina appKey:appKey appSecret:appSecrect redirectURL:redirectURL]; } #pragma mark - 配置系统回调 - (BOOL)application:(UIApplication *)application openURL:(nonnull NSURL *)url sourceApplication:(nullable NSString *)sourceApplication annotation:(nonnull id)annotation { BOOL result = [[UMSocialManager defaultManager] handleOpenURL:url sourceApplication:sourceApplication annotation:annotation]; if (!result) { // 其他如支付等SDK的回调 // 如果有多个回调需求处理的话, 应该再创建一个分类别统一实现回调 } return result; } #pragma mark - 友盟分享方法 /** 分享文本 @param text 要分享的文本 @param callback 回调方法 */ - (void)zx_shareTextWithString:(NSString *)text currentViewController:(UIViewController *)currentVC callback:(UMSocialCallBack)callback { // 创建分享消息对象 UMSocialMessageObject *messageObject = [UMSocialMessageObject messageObject]; // 设置文本 messageObject.text = text; // 调用友盟分享面板 [UMSocialUIManager showShareMenuViewInWindowWithPlatformSelectionBlock:^(UMSocialPlatformType platformType, NSDictionary *userInfo) { // 调用分享接口 [[UMSocialManager defaultManager] shareToPlatform:platformType messageObject:messageObject currentViewController:currentVC completion:^(id result, NSError *error) { if (error) { if (callback) callback(FALSE, result, error); } else { if (callback) callback(TRUE, result, error); } }]; }]; } /** 分享图片 @param image 要分享的图片 @param thumImage 缩略图 @param currentVC 调用分享方法的控制面板 @param callback 回调方法 */ - (void)zx_shareImageWithImage:(UIImage *)image thumImage:(UIImage *)thumImage currentViewController:(UIViewController *)currentVC callback:(UMSocialCallBack)callback { // 创建分享消息对象 UMSocialMessageObject *messageObject = [UMSocialMessageObject messageObject]; // 创建图片内容对象 UMShareImageObject *shareObject = [[UMShareImageObject alloc] init]; // 如果有缩略图, 则设置缩略图 if (thumImage) { shareObject.thumbImage = thumImage; } // 设置分享的图片 if (image) { [shareObject setShareImage:image]; } // 分享消息对象设置分享内容对象 messageObject.shareObject = shareObject; // 调用友盟分享面板 [UMSocialUIManager showShareMenuViewInWindowWithPlatformSelectionBlock:^(UMSocialPlatformType platformType, NSDictionary *userInfo) { [[UMSocialManager defaultManager] shareToPlatform:platformType messageObject:messageObject currentViewController:currentVC completion:^(id result, NSError *error) { if (error) { if (callback) callback(FALSE, result, error); } else { if (callback) callback(TRUE, result, error); } }]; }]; } /** 分享图文 @param text 要分享的文字 @param image 要分享的图片 @param thumImage 缩略图 @param currentVC 调用分享方法的控制面板 @param callback 回调方法 */ - (void)zx_shareTextWithString:(NSString *)text andImage:(UIImage *)image thumImage:(UIImage *)thumImage currentViewController:(UIViewController *)currentVC callback:(UMSocialCallBack)callback { // 创建分享消息对象 UMSocialMessageObject *messageObject = [UMSocialMessageObject messageObject]; // 设置文本 messageObject.text = text; // 创建图片内容对象 UMShareImageObject *shareObject = [[UMShareImageObject alloc] init]; // 如果有缩略图, 则设置缩略图 if (thumImage) { shareObject.thumbImage = thumImage; } // 设置分享的图片 if (image) { [shareObject setShareImage:image]; } // 分享消息对象设置分享内容对象 messageObject.shareObject = shareObject; // 调用分享接口 [UMSocialUIManager showShareMenuViewInWindowWithPlatformSelectionBlock:^(UMSocialPlatformType platformType, NSDictionary *userInfo) { [[UMSocialManager defaultManager] shareToPlatform:platformType messageObject:messageObject currentViewController:currentVC completion:^(id result, NSError *error) { if (error) { if (callback) callback(FALSE, result, error); } else { if (callback) callback(TRUE, result, error); } }]; }]; } /** 分享网页 @param url 要分享的网页地址 @param title 标题 @param description 描述 @param thumImage 缩略图 @param currentVC 调用分享方法的控制面板 @param callback 回调方法 */ - (void)zx_shareWebPageWithURLStr:(NSString *)url title:(NSString *)title description:(NSString *)description thumImage:(UIImage *)thumImage currentViewController:(UIViewController *)currentVC callback:(UMSocialCallBack)callback { // 创建分享消息对象 UMSocialMessageObject *messageObject = [UMSocialMessageObject messageObject]; // 创建网页内容对象 UMShareWebpageObject *shareObject = [UMShareWebpageObject shareObjectWithTitle:title descr:description thumImage:thumImage]; // 设置网页地址 shareObject.webpageUrl = url; // 分享消息对象设置分享内容对象 messageObject.shareObject = shareObject; // 调用分享接口 [UMSocialUIManager showShareMenuViewInWindowWithPlatformSelectionBlock:^(UMSocialPlatformType platformType, NSDictionary *userInfo) { [[UMSocialManager defaultManager] shareToPlatform:platformType messageObject:messageObject currentViewController:currentVC completion:^(id result, NSError *error) { if (error) { if (callback) callback(FALSE, result, error); } else { if (callback) callback(TRUE, result, error); } }]; }]; } /** 分享音乐 @param musicURL 音乐的url @param title 标题 @param description 描述 @param thumImage 缩略图 @param currentVC 调用分享方法的控制面板 @param callback 回调方法 */ - (void)zx_shareMusicWithURLStr:(NSString *)musicURL title:(NSString *)title description:(NSString *)description thumImage:(UIImage *)thumImage currentViewController:(UIViewController *)currentVC callback:(UMSocialCallBack)callback { // 创建分享消息对象 UMSocialMessageObject *messageObject = [UMSocialMessageObject messageObject]; // 创建音乐内容对象 UMShareMusicObject *shareObject = [UMShareMusicObject shareObjectWithTitle:title descr:description thumImage:thumImage]; // 设置音乐网页播放地址 shareObject.musicUrl = musicURL; // 分享消息对象设置分享内容对象 messageObject.shareObject = shareObject; // 调用分享接口 [UMSocialUIManager showShareMenuViewInWindowWithPlatformSelectionBlock:^(UMSocialPlatformType platformType, NSDictionary *userInfo) { [[UMSocialManager defaultManager] shareToPlatform:platformType messageObject:messageObject currentViewController:currentVC completion:^(id result, NSError *error) { if (error) { if (callback) callback(FALSE, result, error); } else { if (callback) callback(TRUE, result, error); } }]; }]; } /** 分享视频 @param videoURL 视频的url @param title 标题 @param description 描述 @param thumImage 缩略图 @param currentVC 调用分享方法的控制面板 @param callback 回调方法 */ - (void)zx_shareVideoWithURLStr:(NSString *)videoURL title:(NSString *)title description:(NSString *)description thumImage:(UIImage *)thumImage currentViewController:(UIViewController *)currentVC callback:(UMSocialCallBack)callback { // 创建分享消息对象 UMSocialMessageObject *messageObject = [UMSocialMessageObject messageObject]; // 创建视频内容对象 UMShareVideoObject *shareObject = [UMShareVideoObject shareObjectWithTitle:title descr:description thumImage:thumImage]; // 设置视频网页播放地址 shareObject.videoUrl = videoURL; // 分享消息对象设置分享内容对象 messageObject.shareObject = shareObject; // 调用分享接口 [UMSocialUIManager showShareMenuViewInWindowWithPlatformSelectionBlock:^(UMSocialPlatformType platformType, NSDictionary *userInfo) { [[UMSocialManager defaultManager] shareToPlatform:platformType messageObject:messageObject currentViewController:currentVC completion:^(id result, NSError *error) { if (error) { if (callback) callback(FALSE, result, error); } else { if (callback) callback(TRUE, result, error); } }]; }]; } /** 分享微信小程序 @param programPath 小程序页面路径 @param webPageURL 兼容网页地址 @param userName 用户名 @param title 小程序标题 @param description 小程序内容描述 @param thumImage 缩略图 @param currentVC 调用分享方法的控制面板 @param callback 回调方法 */ -(void)zx_WeichatMiniProgramWithPath:(NSString *)programPath webPageURL:(NSString *)webPageURL userName:(NSString *)userName title:(NSString *)title description:(NSString *)description thumImage:(UIImage *)thumImage currentViewController:(UIViewController *)currentVC callback:(UMSocialCallBack)callback { // 创建分享消息对象 UMSocialMessageObject *messageObject = [UMSocialMessageObject messageObject]; // 创建小程序消息对象 UMShareMiniProgramObject *shareObject = \\ [UMShareMiniProgramObject shareObjectWithTitle:title descr:description thumImage:thumImage]; shareObject.webpageUrl = webPageURL; shareObject.userName = userName; shareObject.path = programPath; // 分享消息对象设置分享内容对象 messageObject.shareObject = shareObject; // 调用分享接口 [UMSocialUIManager showShareMenuViewInWindowWithPlatformSelectionBlock:^(UMSocialPlatformType platformType, NSDictionary *userInfo) { [[UMSocialManager defaultManager] shareToPlatform:platformType messageObject:messageObject currentViewController:currentVC completion:^(id result, NSError *error) { if (error) { if (callback) callback(FALSE, result, error); } else { if (callback) callback(TRUE, result, error); } }]; }]; } #pragma mark - 友盟登录方法 /** 拉取新浪登录授权信息 @param currentViewController 调用登录的当前控制面板 @param callback 回调方法 */ - (void)zx_getAuthInfoFromSinaWithCurrentViewController:(UIViewController *)currentViewController CallBack:(UMSocialCallBack)callback { [[UMSocialManager defaultManager] getUserInfoWithPlatform:UMSocialPlatformType_Sina currentViewController:currentViewController completion:^(id result, NSError *error) { if (error) { if (callback) callback(FALSE, result, error); } else { if (callback) callback(TRUE, result, error); } }]; } /** 拉取微信登录授权信息 @param currentViewController 调用登录的当前控制面板 @param callback 回调方法 */ - (void)zx_getAuthInfoFromWechatWithCurrentViewController:(UIViewController *)currentViewController CallBack:(UMSocialCallBack)callback { [[UMSocialManager defaultManager] getUserInfoWithPlatform:UMSocialPlatformType_WechatSession currentViewController:currentViewController completion:^(id result, NSError *error) { if (error) { if (callback) callback(FALSE, result, error); } else { if (callback) callback(TRUE, result, error); } }]; } /** 拉取QQ登录授权信息 @param currentViewController 调用登录的当前控制面板 @param callback 回调方法 */ - (void)zx_getAuthInfoFromQQWithCurrentViewController:(UIViewController *)currentViewController CallBack:(UMSocialCallBack)callback { [[UMSocialManager defaultManager] getUserInfoWithPlatform:UMSocialPlatformType_QQ currentViewController:currentViewController completion:^(id result, NSError *error) { if (error) { if (callback) callback(FALSE, result, error); } else { if (callback) callback(TRUE, result, error); } }]; } @end
对应的Appkey放在AppKey.h中
// // AppKey.h // ThirdPartDemo // // Created by Jackey on 2017/7/5. // Copyright © 2017年 com.zhouxi. All rights reserved. // #ifndef AppKey_h #define AppKey_h /* Notice: 以下定义内容, 请不要删除以免编译报错 如果不需要集成某一个SDK, 可以将对应的appKey内容清空, 只保留@"" */ // 友盟推送 #define UMessageAppKey @"57d6583a67e58e3d75001f15" // 友盟分享 #define UMSocialAppKey @"57d6583a67e58e3d75001f15" #define WechatAppKey @"wx406b36767a2d7615" #define WechatAppSecret @"4402d0be403a89f7c0527764371bf46a" #define WeChatRedirectURL @"http://mobile.umeng.com/social" #define QQAppKey @"101390775" #define QQAppSecrect @"09193c1b916f14e07e888c84f16fa797" #define QQRedirectURL @"http://mobile.umeng.com/social" #define SinaAppKey @"3628080196" #define SinaAppSecrect @"584f67d21fca39ad0af7df3706166db1" #define SinaRedirectURL @"https://sns.whalecloud.com/sina2/callback" #endif /* AppKey_h */
使用的时候在AppDelegate.m中中导入
#import "AppDelegate+UMengPush.h" #import "AppDelegate+UMSocial.h"
一行代码配置
- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions { // Override point for customization after application launch. // 配置UMSocial [self zx_configureUMSocialSDK]; return YES; }
在要使用分享的控制器中导入:
#import "AppDelegate.h" #import "AppDelegate+UMengPush.h" #import "AppDelegate+UMSocial.h"
最好把这三个加到pch中
分享部分我们简单以分享文本做个示例
NSLog(@"分享文字"); AppDelegate *app = (AppDelegate *)[[UIApplication sharedApplication] delegate]; [app zx_shareTextWithString:@"分享" currentViewController:self callback:^(BOOL success, id responseObject, NSError *error) { if (success) { NSLog(@"分享成功"); } else { NSLog(@"分享失败"); } }];
三方登录部分我用新浪做个示例
NSLog(@"新浪登录"); AppDelegate *app = (AppDelegate *)[[UIApplication sharedApplication] delegate]; [app zx_getAuthInfoFromSinaWithCurrentViewController:self CallBack:^(BOOL success, id responseObject, NSError *error) { if (success) { UMSocialUserInfoResponse *resp = responseObject; // 授权信息 NSLog(@"Wechat uid: %@", resp.uid); NSLog(@"Wechat openid: %@", resp.openid); NSLog(@"Wechat accessToken: %@", resp.accessToken); NSLog(@"Wechat refreshToken: %@", resp.refreshToken); NSLog(@"Wechat expiration: %@", resp.expiration); // 用户信息 NSLog(@"Wechat name: %@", resp.name); NSLog(@"Wechat iconurl: %@", resp.iconurl); NSLog(@"Wechat gender: %@", resp.unionGender); // 第三方平台SDK源数据 NSLog(@"Wechat originalResponse: %@", resp.originalResponse); } else { NSLog(@"登录失败: %@", error); } }];
最后提
以上是关于AppDelegate减负之常用三方封装 - 友盟分享 / 三方登录篇的主要内容,如果未能解决你的问题,请参考以下文章