AppDelegate减负之常用三方封装 - 友盟分享 / 三方登录篇

时间:2021-07-06 21:48:43

之前完成了 AppDelegate减负之常用三方封装 - 友盟推送篇:

http://www.cnblogs.com/zhouxihi/p/7113511.html

今天接着来完成 - 友盟分享和三方登录篇

首先去友盟上面下载SDK, 一般就新浪/微信/QQ  我们都选择精简版

AppDelegate减负之常用三方封装 - 友盟分享 / 三方登录篇

把下载好的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] > ) { NSLog(@"配置微信");
[self zx_configureWechatShareWithAppKey:WechatAppKey
appSecret:WechatAppSecret
redirectURL:WeChatRedirectURL];
} // 配置QQ
if ([QQAppKey length] > ) { NSLog(@"配置QQ");
[self zx_configureQQShareWithAppKey:QQAppKey
appSecret:QQAppSecrect
redirectURL:QQRedirectURL];
} // 配置Sina
if ([SinaAppKey length] > ) { 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);
}
}];

最后提供Demo地址给大家:

https://github.com/zhouxihi/ThirdPartDemo

欢迎大家提供建议, 如果好用也希望大家帮忙star

谢谢

后面会再做支付部分

AppDelegate减负之常用三方封装 - 友盟分享 / 三方登录篇的更多相关文章

  1. AppDelegate减负之常用三方封装 - 友盟推送篇

    之前分享过集成友盟推送的方法, 需要的朋友可以查看一下链接: http://www.cnblogs.com/zhouxihi/p/6533058.html 一般开发中我们比较多使用的三方有友盟推送, ...

  2. iOS友盟分享的使用总结

    现在几乎所有的APP都会集成分享,为了可以更好的推广自己的APP. 目前市面上常用的分享无非就三个: 1.友盟分享; 2.shareSDK(mob); 3.苹果原生. 由于苹果原生的分享使用起来不方便 ...

  3. iOS开发-友盟分享(3)

    iOS 友盟分享 这个主要是提到如何通过友盟去自定义分享的步骤: 一.肯定要去友盟官网下载最新的SDK包,然后将SDK导入到你的工程文件夹里面去: 二.注册友盟账号,将你的APP添加到你的账号里面然后 ...

  4. iOS开发-友盟分享使用(2)

    1.友盟SDK提供功能:分享喜欢的东西到新浪微博.qq空间.为微信朋友圈等等等等社交圈. 2.友盟分享前期准备 (1)注册账号 去官网 (2)创建应用获取appkey 类似5556a53667e*** ...

  5. 友盟分享--集成QQ和微信

    随着社交工具的应用范围越来越广,分享一些内容的功能也开始要求实现了. 用得比较多的第三方,比如说友盟,比如说Share等等... 前几天刚用友盟写了集成QQ和微信客户端的功能,觉得有必要分享一下. 在 ...

  6. iOS开发——友盟分享

    ==========2016-01-29 更新=====刘成利 email:liu_cheng_li@qq.com========== 自己成功集成到公司的项目前,也已做了测试好的友盟分享demo 目 ...

  7. iOS关于友盟分享弹不出面板问题

    在程序代理类中声明 [NSThread sleepForTimeInterval:10];//设置启动页面时间 [self.window makeKeyAndVisible]; [[UMSocialM ...

  8. IOS 集成友盟分享

    #import <Foundation/Foundation.h> @interface UMSocialSinaHandler : NSObject +(void)openSSOWith ...

  9. 友盟分享小结 - iOS

    因之前都写在了 AppDelegate 类中,看起来过于臃肿,此次基于友盟分享重新进行了一次优化,此次分享内容基于已经成功集成 SDK 后 code 层级部分.注:此次分享基于 SDK 6.9.3,若 ...

随机推荐

  1. JDBC MySQL 多表关联查询查询

    public static void main(String[] args) throws Exception{ Class.forName("com.mysql.jdbc.Driver&q ...

  2. linux C之access函数 &lpar;20

    http://blog.sina.com.cn/s/blog_6a1837e90100uh5d.html linux C之access函数 (20access():判断是否具有存取文件的权限 相关函数 ...

  3. JSP 网页格式判定执行哪一块html

    JSP 网页格式判定执行哪一块html <!-- start -->             <td height="166" colspan="3&q ...

  4. 【VB&sol;&period;NET】Converting VB6 to VB&period;NET 【Part II】【之四】

    第四部分 原文 DLLs, DAO, RDO, ADO, and AD.NET; the History of VB DBs In the early versions of VB, there we ...

  5. Xcode自带iOS测试方法

    在说Xcode自带测试方法前先讲下程序在内存中的空间划分, 一般可分为5个部分: #1. BSS段, 存放未初始化的全局变量. BSS是英文Block Started by Symbol的简称.BSS ...

  6. Java中String字符串常量池总结

    最近到广州某建站互联网公司面试,当时面试官问假设有两个字符串String a="abc",String b = "abc";问输出a==b是true还是fals ...

  7. &lbrack;INet&rsqb; WebSocket 协议中的数据收发过程

    WebSocket 和 HTTP 相似,只是一个应用层协议,对下层透明,所以不涉及 TCP/IP. 由于浏览器支持了 WebSocket,所以在用 JS 写客户端的时候,是无需考虑数据的编码解码的. ...

  8. linux shell中break和continue跳出循环

    到目前为止,我们已经看到了,创建循环和使用循环来完成不同的任务.有时候,你需要停止循环或跳过循环迭代. 在本教程中,您将了解以下两个语句用于控制 Shell 循环: break 语句 continue ...

  9. SVN的Branch和Tag管理

    dev:开发主线 branch: 部分特殊客户的定制化版本 tag: 主线的某个发布版本 release: 主线的里程碑式的发布版本(相比上一里程碑版本,改动非常大,并且当前已经很稳定的) 你可以在b ...

  10. Delphi 判断时间是否合法 -IsValidDateTime、IsValidDate、IsValidTime、IsValidDateDay

    DateUtils.IsValidDateTimeDateUtils.IsValidDateDateUtils.IsValidTimeDateUtils.IsValidDateDayDateUtils ...