1.第三方账号申请
微博: AppID AppKey AppSecret
微信: AppID及AppSecret(有效期为一年)
QQ&空间:AppID及AppKey
2.快速集成文档
使用CocoaPods
target 'UMSocialDemo' do
# U-Share SDK UI??椋ǚ窒砻姘?,建议添加)
pod ‘UMengUShare/UI’
# 集成新浪微博
pod ‘UMengUShare/Social/Sina'
# 集成微信
pod ‘UMengUShare/Social/WeChat'
# 集成QQ
pod ‘UMengUShare/Social/QQ'
end
终端中输入一下数据
$ cd [存放Podfile的项目路径]
$ pod update
不可加入--no-repo-update参数,若添加后仅从本地Cocoapods库中查找SDK,不再更新线上SDK。如果本地存在SDK会直接使用本地SDK版本(不是线上最新版本),若本地不存在SDK会产生错误。 也不建议使用pod install命令,这也是从本地SDK库进行安装的命令。
3.第三方平台设置a:配置SSO白名单使用了如SSO授权登录或跳转到第三方分享功能,在iOS9/10下就需要增加一个可跳转的白名单,即LSApplicationQueriesSchemes,否则将在SDK判断是否跳转时用到的canOpenURL时返回NO,进而只进行webview授权或授权/分享失败。 在项目中的info.plist中加入应用白名单,右键info.plist选择source code打开(plist具体设置在Build Setting -> Packaging -> Info.plist File可获取plist路径) 请根据选择的平台对以下配置进行裁剪:LSApplicationQueriesSchemeswechatweixinsinaweibohdsinaweibosinaweibossoweibosdkweibosdk2.5mqqapimqqmqqOpensdkSSoLoginmqqconnectmqqopensdkdatalinemqqopensdkgrouptribesharemqqopensdkfriendmqqopensdkapimqqopensdkapiV2mqqopensdkapiV3mqqopensdkapiV4mqzoneopensdkwtloginmqqwtloginmqq2mqqwpamqzonemqzonev2mqzonesharewtloginqzonemqzonewxmqzoneopensdkapiV2mqzoneopensdkapi19mqzoneopensdkapimqqbrowsermttbrowserb:URL SchemeURL Scheme是通过系统找到并跳转对应app的一类设置,通过向项目中的info.plist文件中加入URL types可使用第三方平台所注册的appkey信息向系统注册你的app,当跳转到第三方应用授权或分享后,可直接跳转回你的app。添加URL Types可工程设置面板设置
4初始化设置#import在AppDelegate.m中设置如下代码- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions {? ? /* 打开调试日志 */? ? [[UMSocialManager defaultManager] openLog:YES];? ? /* 设置友盟appkey */? ? [[UMSocialManager defaultManager] setUmSocialAppkey:USHARE_DEMO_APPKEY];? ? [self configUSharePlatforms];? ? [self confitUShareSettings];? ? // Custom code? ? return YES;}- (void)confitUShareSettings{? ? /*? ? * 打开图片水印? ? */? ? //[UMSocialGlobal shareInstance].isUsingWaterMark = YES;? ? /*? ? * 关闭强制验证https,可允许http图片分享,但需要在info.plist设置安全域名NSAppTransportSecurityNSAllowsArbitraryLoads*/? ? //[UMSocialGlobal shareInstance].isUsingHttpsWhenShareContent = NO;}- (void)configUSharePlatforms{? ? /* 设置微信的appKey和appSecret */? ? [[UMSocialManager defaultManager] setPlaform:UMSocialPlatformType_WechatSession appKey:@"wxdc1e388c3822c80b" appSecret:@"3baf1193c85774b3fd9d18447d76cab0" redirectURL:@"http://mobile.umeng.com/social"];? ? /*? ? * 移除相应平台的分享,如微信收藏? ? */? ? //[[UMSocialManager defaultManager] removePlatformProviderWithPlatformTypes:@[@(UMSocialPlatformType_WechatFavorite)]];? ? /* 设置分享到QQ互联的appID? ? * U-Share SDK为了兼容大部分平台命名,统一用appKey和appSecret进行参数设置,而QQ平台仅需将appID作为U-Share的appKey参数传进即可。? ? */? ? [[UMSocialManager defaultManager] setPlaform:UMSocialPlatformType_QQ appKey:@"1105821097"/*设置QQ平台的appID*/? appSecret:nil redirectURL:@"http://mobile.umeng.com/social"];? ? /* 设置新浪的appKey和appSecret */? ? [[UMSocialManager defaultManager] setPlaform:UMSocialPlatformType_Sina appKey:@"3921700954"? appSecret:@"04b48b094faeb16683c32669824ebdad" redirectURL:@"https://sns.whalecloud.com/sina2/callback"]; /* 支付宝的appKey */? ? [[UMSocialManager defaultManager] setPlaform: UMSocialPlatformType_AlipaySession appKey:@"2015111700822536" appSecret:nil redirectURL:@"http://mobile.umeng.com/social"];}
5.设置系统回调// 支持所有iOS系统- (BOOL)application:(UIApplication *)application openURL:(NSURL *)url sourceApplication:(NSString *)sourceApplication annotation:(id)annotation{? ? BOOL result = [[UMSocialManager defaultManager] handleOpenURL:url];? ? if (!result) {? ? ? ? // 其他如支付等SDK的回调? ? }? ? return result;}//支持iOS 9+- (BOOL)application:(UIApplication *)app openURL:(NSURL *)url options:(NSDictionary*)options
{
BOOL result = [[UMSocialManager defaultManager] handleOpenURL:url];
if (!result) {
// 其他如支付等SDK的回调
}
return result;
}
//
- (BOOL)application:(UIApplication *)application handleOpenURL:(NSURL *)url
{
BOOL result = [[UMSocialManager defaultManager] handleOpenURL:url];
if (!result) {
// 其他如支付等SDK的回调
}
return result;
}
6第三方登录// 在需要进行获取登录信息的UIViewController中加入如下代码#import- (void)getUserInfoForPlatform:(UMSocialPlatformType)platformType
{
[[UMSocialManager defaultManager] getUserInfoWithPlatform:platformType currentViewController:self completion:^(id result, NSError *error) {
UMSocialUserInfoResponse *resp = result;
// 第三方登录数据(为空表示平台未提供)
// 授权数据
NSLog(@" uid: %@", resp.uid);
NSLog(@" openid: %@", resp.openid);
NSLog(@" accessToken: %@", resp.accessToken);
NSLog(@" refreshToken: %@", resp.refreshToken);
NSLog(@" expiration: %@", resp.expiration);
// 用户数据
NSLog(@" name: %@", resp.name);
NSLog(@" iconurl: %@", resp.iconurl);
NSLog(@" gender: %@", resp.gender);
// 第三方平台SDK原始数据
NSLog(@" originalResponse: %@", resp.originalResponse);
}];
}
7.调用友盟的分享面板#import//显示分享面板
[UMSocialUIManager showShareMenuViewInWindowWithPlatformSelectionBlock:^(UMSocialPlatformType platformType, NSDictionary *userInfo) {
// 根据获取的platformType确定所选平台进行下一步操作
}];
8? 第三方平台登录授权并获取用户信息// 在需要进行获取登录信息的UIViewController中加入如下代码#import- (void)getUserInfoForPlatform:(UMSocialPlatformType)platformType{? ? [[UMSocialManager defaultManager] getUserInfoWithPlatform:platformType currentViewController:self completion:^(id result, NSError *error) {? ? ? ? UMSocialUserInfoResponse *resp = result;? ? ? ? // 第三方登录数据(为空表示平台未提供)? ? ? ? // 授权数据? ? ? ? NSLog(@" uid: %@", resp.uid);? ? ? ? NSLog(@" openid: %@", resp.openid);? ? ? ? NSLog(@" accessToken: %@", resp.accessToken);? ? ? ? NSLog(@" refreshToken: %@", resp.refreshToken);? ? ? ? NSLog(@" expiration: %@", resp.expiration);? ? ? ? // 用户数据? ? ? ? NSLog(@" name: %@", resp.name);? ? ? ? NSLog(@" iconurl: %@", resp.iconurl);? ? ? ? NSLog(@" gender: %@", resp.gender);? ? ? ? // 第三方平台SDK原始数据? ? ? ? NSLog(@" originalResponse: %@", resp.originalResponse);? ? }];}a:新浪微博:授权并获取用户信息(获取uid、access token及用户名等)// 在需要进行获取用户信息的UIViewController中加入如下代码#import- (void)getAuthWithUserInfoFromSina{? ? [[UMSocialManager defaultManager] getUserInfoWithPlatform:UMSocialPlatformType_Sina currentViewController:nil completion:^(id result, NSError *error) {? ? ? ? if (error) {? ? ? ? } else {? ? ? ? ? ? UMSocialUserInfoResponse *resp = result;? ? ? ? ? ? // 授权信息? ? ? ? ? ? NSLog(@"Sina uid: %@", resp.uid);? ? ? ? ? ? NSLog(@"Sina accessToken: %@", resp.accessToken);? ? ? ? ? ? NSLog(@"Sina refreshToken: %@", resp.refreshToken);? ? ? ? ? ? NSLog(@"Sina expiration: %@", resp.expiration);? ? ? ? ? ? // 用户信息? ? ? ? ? ? NSLog(@"Sina name: %@", resp.name);? ? ? ? ? ? NSLog(@"Sina iconurl: %@", resp.iconurl);? ? ? ? ? ? NSLog(@"Sina gender: %@", resp.gender);? ? ? ? ? ? // 第三方平台SDK源数据? ? ? ? ? ? NSLog(@"Sina originalResponse: %@", resp.originalResponse);? ? ? ? }? ? }];}b:qq:? 授权并获取用户信息(获取uid、access token及用户名等)- (void)getAuthWithUserInfoFromQQ{? ? [[UMSocialManager defaultManager] getUserInfoWithPlatform:UMSocialPlatformType_QQ currentViewController:nil completion:^(id result, NSError *error) {? ? ? ? if (error) {? ? ? ? } else {? ? ? ? ? ? UMSocialUserInfoResponse *resp = result;? ? ? ? ? ? // 授权信息? ? ? ? ? ? NSLog(@"QQ uid: %@", resp.uid);? ? ? ? ? ? NSLog(@"QQ openid: %@", resp.openid);? ? ? ? ? ? NSLog(@"QQ accessToken: %@", resp.accessToken);? ? ? ? ? ? NSLog(@"QQ expiration: %@", resp.expiration);? ? ? ? ? ? // 用户信息? ? ? ? ? ? NSLog(@"QQ name: %@", resp.name);? ? ? ? ? ? NSLog(@"QQ iconurl: %@", resp.iconurl);? ? ? ? ? ? NSLog(@"QQ gender: %@", resp.gender);? ? ? ? ? ? // 第三方平台SDK源数据? ? ? ? ? ? NSLog(@"QQ originalResponse: %@", resp.originalResponse);? ? ? ? }? ? }];}c:3? 微信:授权并获取用户信息(获取uid、access token及用户名等)注意这里的uid为unionID// 在需要进行获取用户信息的UIViewController中加入如下代码#import- (void)getAuthWithUserInfoFromWechat
{
[[UMSocialManager defaultManager] getUserInfoWithPlatform:UMSocialPlatformType_WechatSession currentViewController:nil completion:^(id result, NSError *error) {
if (error) {
} else {
UMSocialUserInfoResponse *resp = result;
// 授权信息
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.gender);
// 第三方平台SDK源数据
NSLog(@"Wechat originalResponse: %@", resp.originalResponse);
}
}];
}