美文网首页
iOS第三方分享登入功能(原平台+友盟)

iOS第三方分享登入功能(原平台+友盟)

作者: 三好夫人 | 来源:发表于2018-02-06 00:33 被阅读0次

第三方分享有很多第三方集成平台-友盟,mob,极光等
还有一种是下载各个第三方平台的sdk各个集成
无论是用原平台sdk还是第三方平台sdk我们都需要项目配置所以第一步通用配置
先用平台各个集成然后在第三方平台集成这篇不涉及各平台申请appid和key过程

第一步项目配置
1)设置白名单 targets-info—URL Types中
2)在plist中添加数组字段LSApplicationQueriesSchemes
技巧:点plist右击可以open as切换到code模式添加
<key>LSApplicationQueriesSchemes</key>
<array>
<string>wechat</string>
<string>weixin</string>
<string>mqqapi</string>
<string>mqq</string>
<string>mqqOpensdkSSoLogin</string>
<string>mqqconnect</string>
<string>mqqopensdkdataline</string>
<string>mqqopensdkgrouptribeshare</string>
<string>mqqopensdkfriend</string>
<string>mqqopensdkapi</string>
<string>mqqopensdkapiV2</string>
<string>mqqopensdkapiV3</string>
<string>mqqopensdkapiV4</string>
<string>mqzoneopensdk</string>
<string>wtloginmqq</string>
<string>wtloginmqq2</string>
<string>mqqwpa</string>
<string>mqzone</string>
<string>mqzonev2</string>
<string>mqzoneshare</string>
<string>wtloginqzone</string>
<string>mqzonewx</string>
<string>mqzoneopensdkapiV2</string>
<string>mqzoneopensdkapi19</string>
<string>mqzoneopensdkapi</string>
<string>mqqbrowser</string>
<string>mttbrowser</string>
<string>sinaweibohd</string>
<string>sinaweibo</string>
<string>sinaweibosso</string>
<string>weibosdk</string>
<string>weibosdk2.5</string>
</array>

3)导入依赖库SystemConfiguration
4)build settings ->other linker flags中-ObjC

第二部 集成步骤(qq,微信,微博)
QQ
qqsdk包经常变以前会有一个素材包我刚下载的没有了
//http://wiki.connect.qq.comqq开发文档
//http://wiki.open.qq.com/wiki/【QQ登录】SDK下载
qq:TencentOpenAPI.framework

import <TencentOpenAPI/TencentOAuth.h>

在 AppDelegate应用入口或者需要分享的地方添加
由于分享不需要授权回调没有申请代理
TencentOAuth *te =[[TencentOAuth alloc]initWithAppId:QQAPIID andDelegate:nil];
在viewcontroller

import <TencentOpenAPI/TencentOAuth.h>

import <TencentOpenAPI/QQApiInterfaceObject.h>

import <TencentOpenAPI/QQApiInterface.h>

//初始化;
TencentOAuth *ten = [[TencentOAuth alloc]initWithAppId:QQAPIID andDelegate:nil];
//分享类型枚举
QQApiURLObject *urlobject = [QQApiURLObject objectWithURL:[NSURL URLWithString:@"http://open.qq.com"] title:@"你好" description:@"我好喜欢你" previewImageData:UIImageJPEGRepresentation([UIImage imageNamed:@"tubiao"], 1) targetContentType:QQApiURLTargetTypeNews];

    SendMessageToQQReq *req = [SendMessageToQQReq reqWithContent:urlobject];
    
    
    //分享好友
    QQApiSendResultCode sent = [QQApiInterface sendReq:req];
     //空间

// QQApiSendResultCode sent = [QQApiInterface SendReqToQZone:req];

———————————
微博
https://github.com/sinaweibosdk/weibo_ios_sdk
下载weibosdk将libWeiboSDK导入项目
导入依赖库
QuartzCore.framework
ImageIO.framework
SystemConfiguration.framework
Security.framework
CoreTelephony.framework
CoreText.framework
UIKit.framework
Foundation.framework
CoreGraphics.framework
libz.dylib
libsqlite3.dylib
坑点:官方文档漏掉一个系统库
photos.framework!
不加入的会报错如下
Undefined symbols for architecture arm64:
"OBJC_CLASS$_PHAsset", referenced from:

最后在
方法:程序 Target->Buid Settings->Linking 下 OtherLinker Flags 项添加 -ObjC。
不添加汇报一个bug
[UIDevice wbsdk_plainDeviceID]: unrecognized selector sent to class 0x1a8382ab0

使用
在Appdelegate程序里入口处获知使用分享的地方添加
[WeiboSDK registerApp:WB_KEY];
//打开调试窗口
[WeiboSDK enableDebugMode:YES];

WBAuthorizeRequest *WbAuthRequest = [WBAuthorizeRequest request];

//授权回调
WbAuthRequest.redirectURI = @"http://www.baidu.com";

WbAuthRequest.scope = @"all";

//分享文本信息
WBMessageObject *message = [WBMessageObject message];
message.text = @"你好我想你";

// 消息的图片内容中,图片数据不能为空并且大小不能超过10M
WBImageObject *imageObject = [WBImageObject object];
imageObject.imageData = UIImageJPEGRepresentation([UIImage imageNamed:@"tubiao"], 1.0);
message.imageObject = imageObject;

WBSendMessageToWeiboRequest *request = [WBSendMessageToWeiboRequest requestWithMessage:message];
[WeiboSDK sendRequest:request];

完成了
注意:如果项目中需要使用登入功能那么要在appdelegate中的openurl代理方法中接收回调

微信
官方下载资源包:手动导入获知pod
手动导入将资源包中的
libWeChatSDK.a
WechatAuthSDK.h
WXApi.h
WXApiObject.h
添加以下依赖库
SystemConfiguration.framework,
libz.dylib,
libsqlite3.0.dylib,
libc++.dylib,
Security.framework,
CoreTelephony.framework,
CFNetwork.framework。
最后在
Other Linker Flags"中加入-ObjC -all_load
注意:官方文档和他们的案列demo写错了注意
//微信

import "WXApi.h"

[WXApi registerApp:@"wx0105fa0fa5ed69a1"];

//创建发送对象实例
SendMessageToWXReq *sendReq = [[SendMessageToWXReq alloc] init];
sendReq.bText = NO;//不使用文本信息
sendReq.scene = 1;//0 = 好友列表 1 = 朋友圈 2 = 收藏
//创建分享内容对象
WXMediaMessage *urlMessage = [WXMediaMessage message];
urlMessage.title = @"你好";//分享标题
urlMessage.description = @"测试";//分享描述
[urlMessage setThumbImage:[UIImage imageNamed:@"tubiao"]];//分享图片,使用SDK的setThumbImage方法可压缩图片大小

// /创建多媒体对象
WXWebpageObject *webObj = [WXWebpageObject object];
webObj.webpageUrl = @"www.baidu.com";//分享链接

//完成发送对象实例
urlMessage.mediaObject = webObj;
sendReq.message = urlMessage;

//发送分享信息
[WXApi sendReq:sendReq];

—————完成

友盟分享
导入友盟sdk
Other Linker Flags"中加入-ObjC
添加依赖库
libsqlite3.tbd
CoreGraphics.framework
· 微信(完整版)-精简版无需添加以下依赖库
SystemConfiguration.framework
CoreTelephony.framework
libsqlite3.tbd
libc++.tbd
libz.tbd

·   QQ/QZone/TIM(完整版)-精简版无需添加以下依赖库

SystemConfiguration.framework
libc++.tbd

·   新浪微博(完整版)-精简版无需添加以下依赖库

SystemConfiguration.framework
CoreTelephony.framework
ImageIO.framework
libsqlite3.tbd
libz.tbd
· Twitter
CoreData.framework
· 短信
MessageUI.framework

在delegate中

import <UMSocialCore/UMSocialCore.h>

初始化um
/* 打开调试日志 */
[[UMSocialManager defaultManager] openLog:YES];

/* 设置友盟appkey */
[[UMSocialManager defaultManager] setUmSocialAppkey:USHARE_DEMO_APPKEY];

//设置平台key 和secret
[[UMSocialManager defaultManager] setPlaform:UMSocialPlatformType_WechatSession appKey:@"id" appSecret:@“key” redirectURL:nil];

  • (BOOL)application:(UIApplication *)app openURL:(NSURL *)url options:(NSDictionary<UIApplicationOpenURLOptionsKey, id> *)options
    {
    //6.3的新的API调用,是为了兼容国外平台(例如:新版facebookSDK,VK等)的调用[如果用6.2的api调用会没有回调],对国内平台没有影响
    BOOL result = [[UMSocialManager defaultManager] handleOpenURL:url options:options];
    if (!result) {
    // 其他如支付等SDK的回调
    }
    return result;
    }
  • (BOOL)application:(UIApplication *)application handleOpenURL:(NSURL *)url
    {
    BOOL result = [[UMSocialManager defaultManager] handleOpenURL:url];
    if (!result) {
    // 其他如支付等SDK的回调
    }
    return result;
    }

分享界面vc中添加

import <UShareUI/UShareUI.h>

//创建分享消息对象
UMSocialMessageObject *messageObject = [UMSocialMessageObject messageObject];
//设置文本
messageObject.text = @"社会化组件UShare将各大社交平台接入您的应用,快速武装App。";

//规划平台
__weak typeof(self) weakSelf = self;
[UMSocialUIManager showShareMenuViewInWindowWithPlatformSelectionBlock:^(UMSocialPlatformType platformType, NSDictionary *userInfo) {
    [weakSelf shareTextToPlatformType:platformType];
    
}];

-(void)shareTextToPlatformType:(UMSocialPlatformType)platformtype{

//创建分享消息对象
UMSocialMessageObject *messageObject = [UMSocialMessageObject messageObject];
//设置文本
messageObject.text = @"社会化组件UShare将各大社交平台接入您的应用,快速武装App。";
//调用分享接口
[[UMSocialManager defaultManager] shareToPlatform:platformtype messageObject:messageObject currentViewController:self completion:^(id data, NSError *error) {
    if (error) {
        NSLog(@"************失败错误码%@*********",error);
    }else{
        NSLog(@"response data%@",data);
    }
}];

}

第三方登入友盟
在分享的基础上

  • (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.unionGender);
      
      // 第三方平台SDK原始数据
      NSLog(@" originalResponse: %@", resp.originalResponse);
    

    }];
    }

相关文章

网友评论

      本文标题:iOS第三方分享登入功能(原平台+友盟)

      本文链接:https://www.haomeiwen.com/subject/xgswzxtx.html