iOS 社交化分享功能
iOS 开发过程中可能会遇到需要进行第三方分享的需求,比如向QQ,微信,微博等分享
如下图
我们今天要讲到的方式是使用了一个第三方工具: http://www.sharesdk.cn
一,注册账号
去官网注册:http://www.sharesdk.cn
创建应用,最终获得 App Key,App Secret
二,SDK集成
下载SDK
把下载的SDK拖到项目工程,在弹出的对话框中选中"Copy items if needed"和"Create groups",并点击“Finish“按钮
添加依赖库文件
必须添加的依赖库:
SystemConfiguration.framework
QuartzCore.framework
CoreTelephony.framework
libicucore.dylib
libz.1.2.5.dylib
Security.framework
根据社交平台需要添加的依赖库
Social.framework 腾讯微博
Accounts.framework 腾讯微博
MessageUI.framework 短信和邮件
libstdc++.dylib QQ好友和QQ空间SSO授权需要(新注册的腾讯开放平台帐号只支持SSO授权权限)
libsqlite3.dylib QQ好友和QQ空间SSO授权需要(新注册的腾讯开放平台帐号只支持SSO授权权限)
CoreMotion.framework Google+
CoreLocation.framework Google+
MediaPlayer.framework Google+
CoreText.framework Google+
AssetsLibrary.framework Google+
AddressBook.framework Google+到此为止SDK集成就算完成 下来我们开始代码部分
三,初始ShareSDK和社交平台
在AppDelegate.m中添加ShareSDK头文件
1.设置根视图控制器
必须设置rootViewController。如果使用storyBoard,系统会自动设置根视图控制器。
- - (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions {
- // Override point for customization after application launch.
- _window=[[UIWindow alloc]initWithFrame:[UIScreen mainScreen].bounds];
- _window.backgroundColor =[UIColor colorWithRed:249/255.0 green:249/255.0 blue:249/255.0 alpha:1];
- HelpViewController *mainController=[[HelpViewController alloc]init];
- _window.rootViewController=mainController;
- [_window makeKeyAndVisible];
- return YES;
- }
以上示例代码中讲 HelpViewController 的一个对象设置为了 此应用的rootViewcontroller;
2.初始化ShareSDK
导入头文件,加上初始化方法。
- #import <ShareSDK/ShareSDK.h>
- //1.初始化ShareSDK应用,字符串"iosv1101"是应该换成你申请的ShareSDK应用中的Appkey
- [ShareSDK registerApp:@"iosv1101"];
- //2. 初始化社交平台
- //2.1 代码初始化社交平台的方法
- [self initializePlat];
[self initializePlat ] 方法见下一步(此处以微信,qq,腾讯微博 ,新浪微博为例);
3.初始化社交平台
可以用代码初始化或在ShareSDK开发者后台的社会化平台设置中填入社交平台的信息。
- #import "WXApi.h"
- #import "WeiboSDK.h"
- #import "WeiboApi.h"
- #import <TencentOpenAPI/QQApi.h>
- #import <TencentOpenAPI/QQApiInterface.h>
- #import <TencentOpenAPI/TencentOAuth.h>
社交平台的AppKey、AppSecret、回调地址等需要您自已去相应平台新建应用获取。
- - (void)initializePlat
- {
- /**
- 连接微信应用以使用相关功能,此应用需要引用WeChatConnection.framework和微信官方SDK
- http://open.weixin.qq.com上注册应用,并将相关信息填写以下字段
- **/
- [ShareSDK connectWeChatWithAppId:@""
- appSecret:@""
- wechatCls:[WXApi class]];
- /**
- 连接QQ应用以使用相关功能,此应用需要引用QQConnection.framework和QQApi.framework库
- http://mobile.qq.com/api/上注册应用,并将相关信息填写到以下字段
- **/
- //旧版中申请的AppId(如:QQxxxxxx类型),可以通过下面方法进行初始化
- // [ShareSDK connectQQWithAppId:@"QQ075BCD15" qqApiCls:[QQApi class]];
- [ShareSDK connectQQWithQZoneAppKey:@""
- qqApiInterfaceCls:[QQApiInterface class]
- tencentOAuthCls:[TencentOAuth class]];
- //
- /**
- 连接腾讯微博开放平台应用以使用相关功能,此应用需要引用TencentWeiboConnection.framework
- http://dev.t.qq.com上注册腾讯微博开放平台应用,并将相关信息填写到以下字段
- 如果需要实现SSO,需要导入libWeiboSDK.a,并引入WBApi.h,将WBApi类型传入接口
- **/
- [ShareSDK connectTencentWeiboWithAppKey:@""
- appSecret:@""
- redirectUri:@"http://www.sharesdk.cn"
- wbApiCls:[WeiboApi class]];
- //
- /**
- 连接QQ空间应用以使用相关功能,此应用需要引用QZoneConnection.framework
- http://connect.qq.com/intro/login/上申请加入QQ登录,并将相关信息填写到以下字段
- 如果需要实现SSO,需要导入TencentOpenAPI.framework,并引入QQApiInterface.h和TencentOAuth.h,将QQApiInterface和TencentOAuth的类型传入接口
- **/
- // [ShareSDK connectQZoneWithAppKey:@""
- // appSecret:@""
- // qqApiInterfaceCls:[QQApiInterface class]
- // tencentOAuthCls:[TencentOAuth class]];
- /**
- 连接新浪微博开放平台应用以使用相关功能,此应用需要引用SinaWeiboConnection.framework
- http://open.weibo.com上注册新浪微博开放平台应用,并将相关信息填写到以下字段
- **/
- [ShareSDK connectSinaWeiboWithAppKey:@""
- appSecret:@""
- redirectUri:@"http://www.sharesdk.cn"];
- }
四,设置URL Scheme
1.需要依赖客户端分享或者要支持SSO授权(可以理解成跳到客户端授权)的平台都需要配置平台的URL Scheme(应用分享到社交平台后通过识别URL Scheme返回应用)。具体配置URL Scheme请参考iOS配置SSO授权
(http://wiki.mob.com/%E9%85%8D%E7%BD%AEsso%E6%8E%88%E6%9D%83-2/)。
2.需要在AppDelegate.m中添加处理打开链接的方法
- - (BOOL)application:(UIApplication *)application
- handleOpenURL:(NSURL *)url
- {
- return [ShareSDK handleOpenURL:url
- wxDelegate:self];
- }
- - (BOOL)application:(UIApplication *)application
- openURL:(NSURL *)url
- sourceApplication:(NSString *)sourceApplication
- annotation:(id)annotation
- {
- return [ShareSDK handleOpenURL:url
- sourceApplication:sourceApplication
- annotation:annotation
- wxDelegate:self];
- }
五,构造分享内容并分享
1.构造一个id<ISSContent>类型的对象,把需要分享的标题、内容、图片、URL等 包装在这个对象。
在需要分享的viewController 中导入头文件
- #import <ShareSDK/ShareSDK.h>
在需要分享的地方 实现如下方法
比如在点击一个button的时候调用方法 shareAct
- -(void)shareAct:(id)sender
- {
- //
- NSString *imagePath = [[NSBundle mainBundle] pathForResource:@"ShareSDK" ofType:@"jpg"];
- //1、构造分享内容
- id<ISSContent> publishContent = [ShareSDK content:@"要分享的内容"
- defaultContent:@"默认内容"
- image:[ShareSDK imageWithPath:imagePath]
- title:@"ShareSDK"
- url:@"http://www.mob.com"
- description:@"这是一条演示信息"
- mediaType:SSPublishContentMediaTypeNews];
- //1+创建弹出菜单容器(iPad必要)
- id<ISSContainer> container = [ShareSDK container];
- [container setIPadContainerWithView:sender arrowDirect:UIPopoverArrowDirectionUp];
- //2、弹出分享菜单
- [ShareSDK showShareActionSheet:container
- shareList:nil
- content:publishContent
- statusBarTips:YES
- authOptions:nil
- shareOptions:nil
- result:^(ShareType type, SSResponseState state, id<ISSPlatformShareInfo> statusInfo, id<ICMErrorInfo> error, BOOL end) {
- //可以根据回调提示用户。
- if (state == SSResponseStateSuccess)
- {
- UIAlertView *alert = [[UIAlertView alloc] initWithTitle:@"分享成功"
- message:nil
- delegate:self
- cancelButtonTitle:@"OK"
- otherButtonTitles:nil, nil nil];
- [alert show];
- }
- else if (state == SSResponseStateFail)
- {
- UIAlertView *alert = [[UIAlertView alloc] initWithTitle:@"分享失败"
- message:[NSString stringWithFormat:@"失败描述:%@",[error errorDescription]]
- delegate:self
- cancelButtonTitle:@"OK"
- otherButtonTitles:nil, nil nil];
- [alert show];
- }
- }];
- }
到此基本完成
测试一下 点击微博分享
iOS 社交化分享功能的更多相关文章
- cordova 插件 调用iOS社交化分享(ShareSDK:微信QQ分享)
1.github上已有的插件:https://github.com/nwpuhmz/ShareSDKPlugin 2.安装插件 cordova plugin add https://github.co ...
- iOS开发- 三步快速集成社交化分享工具ShareSDK
1.前言 作为现在App里必不可少的用户分享需要,社交化分享显然是我们开发app里较为常用的. 最近因为公司App有社交化分享的需要,就特此研究了会,拿出来与大家分享. 想要集成社交会分享,我们可以使 ...
- iOS- 三步快速集成社交化分享工具ShareSDK
http://www.cnblogs.com/qingche/p/3727559.html 1.前言 作为现在App里必不可少的用户分享需要,社交化分享显然是我们开发app里较为常用的. 最近因为公司 ...
- 社交化分享SDK for Unity
前言 社交化分享,即分享到社交网络. 本文主要记录的是在Unity集成社交化分享SDK,现主流的分享SDK有如下: 1.友盟社交化分享 for unity 2.ShareSDK分享 for unity ...
- HtmlAgilityPack解析器在WP8.1下报错,不仅如此,社交化分享也报错。
以前WP7下是用的HtmlAgilityPack和 XPath来解析网页,很好用. 但是在Wp8.1下,这个里面却缺少了一个很重要的方法. HtmlDocument doc = new HtmlDoc ...
- iOS ShareSDK 三方分享/登录使用
原文 http://www.cnblogs.com/CoderAlex/p/4860352.html 一: 快速集成 1.前言 作为现在App里必不可少的用户分享需要,社交化分享显然是我们开发app里 ...
- iOS快速集成友盟社会化分享功能(v6.1.1)
1. U-Share SDK集成 1.1 下载U-Share SDK 通过iOS社会化组件选择所需的社交平台后进行下载,下载链接http://dev.umeng.com/social/ios/sdk ...
- 浅谈iOS与社交化网络
CHENYILONG Blog 社交化网络 技术博客http://www.cnblogs.com/ChenYilong/ 新浪微博http://weibo.com/luohanchenyilong ...
- iOS系统自带分享功能
很多APP中都带有社交分享功能,通过用户的分享,让更多地人去了解和使用这个APP,目前社交分享是移动互联网应用程序推广的最重要手段之一,国内较或的分享平台有微信,IOS6后苹果集成的新浪微博,还有IO ...
随机推荐
- oracle索引建立和删除
1.多列建立索引 SQL> create index dex_index2 on dex(sex,name); Index created. SQL> select object_name ...
- WEB 集群与负载均衡(一)基本概念-上
Web集群是由多个同时运行同一个web应用的服务器组成,在外界看来就像一个服务器一样,这多台服务器共同来为客户提供更高性能的服务.集群更标准的定义是:一组相互独立的服务器在网络中表现为单一的系统,并以 ...
- Apache Flink Quickstart
Apache Flink 是新一代的基于 Kappa 架构的流处理框架,近期底层部署结构基于 FLIP-6 做了大规模的调整,我们来看一下在新的版本(1.6-SNAPSHOT)下怎样从源码快速编译执行 ...
- Day4_闭包含数
闭包函数: 闭包函数是在作用域的前提下 闭包含数:定义在函数内部的函数,包含对外部作用域名字的引用,而不是对全局作用域名字的引用,那么该内部函数就称为闭包含数. eg: x=1 def f1(): x ...
- .net c#获取自定义Attribute
前言: 在c#开发中,有时候我们需要读取 Attribute中的信息(关于Attribute , 我自己把他理解成一个可以为类,属性标记的东西,这个标记可以为你提供一些关于类,方法,属性的额外信息) ...
- C++std函数之transform
/*//////////////////////////////// template < class InputIterator, class OutputIterator, class Un ...
- Linux下高并发socket最大连接数
http://soft.chinabyte.com/os/285/12349285.shtml (转载时原文内容做个修改) 1.修改用户进程可打开文件数限制 在Linux平台上,无论编写客户端程序还是 ...
- Java虚拟机-内存tips
java虚拟机内存可以分为独占区和共享区. 独占区:虚拟内存栈.本地方法栈.程序计数器. 共享区:方法区.Java堆(用来存放对象实例). 程序计数器 比较小的内存空间,当前线程所执行的字节码的行号指 ...
- Python测试远程端口连接时间
问题 最近自己服务器访问别人的服务器,有时候会报超时错误,有时候又能够正常访问别人服务器. 思路 最开始猜测是网络不稳定造成的,但是自己没有收集什么时候超时,什么时候能正常访问别人服务器的日志,搞网络 ...
- ubuntu 命令整合1
一.linux命令基本格式 命令名[选项] [参数] 注意: 命令名区分字母大小写 命令名必须有 选项.参数可以没有,选项一般使用减号开头二.具体Linux命令 1.who 显示登录系统中的用户的信息 ...