iOS新浪微博、腾讯微博分享功能实例

一个是新浪微博,腾讯微博的分享按钮,一个是他们的绑定情况(其实就是是否授权)。点击微博分享中新浪或腾讯按钮,就进行相应的授权(若没授权),显示微博内容,而后发布微博。设置界面中的绑定,就是相关的应用授权。 呵呵,其实也蛮简单滴。

首先分别从新浪微博开放平台(http://open.weibo.com/)、腾讯微博开放平台(http://dev.t.qq.com/)中注册应用,获取到Appkey,AppSecret和AppURL(其中

AppURL是要自己填写的)。

然后分别下载相关的SDK.

http://wiki.open.t.qq.com/index.PHP/SDK%E4%B8%8B%E8%BD%BD#iOS_SDK

http://open.weibo.com/wiki/SDK

呵呵,上面这些都是些预备工作。下面正式开发。

建立一个工程,取名sinaqqbo,加入相关sdk文件。 总共5个文件:sina:libWeiboSDK.a,WeiboSDK.bundle 和WeiboSDK.h     qq:libTCWeiboSDK.a  WeiboApi.h

然后设置Info.plist文件的URL types键值,这个的作用是新浪客户端或腾讯客户端能回调到我们的程序来。他们通过一个bundle id 和这里设置的URL Schemes键值就会相应我们app的AppDelete中的 (BOOL)application:(UIApplication *)application openURL:(NSURL *)url sourceApplication:(NSString *)sourceApplication annotation:(id)annotation委托 函数。

URL Schemes  的键值为 wb + AppKey。 腾讯和新浪两个就要建立两个数值。
以上就是工程上设置。
下面具体代码

// AppDelegate.h
#import "WeiboSDK.h"
#import "WeiboApi.h"
@interface AppDelegate : UIResponder <UIApplicationDelegate,WeiboSDKDelegate,WBHttpRequestDelegate> {
 BOOL bSinaWB;
 NSString *sinaAccessToken;
}
@property (strong,nonatomic) WeiboApi   *qqwbAppDelete; //对腾讯微博的处理。做一个全局的变量
//////////////////////////////////////////
// AppDelegate.m
#define sinaAppKey           @"yyyyyyyy"
#define sinaAppSecret           @"yyyyyyyyyyyyyyyyyyyyyyyyyy"
#define sinaAppURL           @"https://api.weibo.com/oauth2/default.html"
#define qqAppKey            @"xxxxxx"
#define qqAppSecret           @"xxxxxxxxxxxxxxxxxxxxxxxxx"
#define qqAppURL            @"https://api.weibo.com/oauth2/default.html"
- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions
{
 [WeiboSDK enableDebugMode:YES];
 [WeiboSDK registerApp:sinaAppKey];
}

//新浪,腾讯客户端调用接口
- (BOOL)application:(UIApplication *)application openURL:(NSURL *)url sourceApplication:(NSString*)sourceApplication annotation:(id)annotation
{
 if (bSinaWB) {
  return [WeiboSDKhandleOpenURL:url delegate:self];
 }
 else {
  return [_qqwbAppDeletehandleOpenURL:url];
 }

}
- (BOOL)application:(UIApplication *)application handleOpenURL:(NSURL *)url
{
 if (bSinaWB) {
  return [WeiboSDKhandleOpenURL:url delegate:self];
 }
 else {
  return [_qqwbAppDeletehandleOpenURL:url] ;
 }
}
以下处理sina的相关
- (void)didReceiveWeiboRequest:(WBBaseRequest *)request
{
}
- (void)didReceiveWeiboResponse:(WBBaseResponse *)response {
 if ([responseisKindOfClass:WBSendMessageToWeiboResponse.class])
 {
  switch (response.statusCode) {
   caseWeiboSDKResponseStatusCodeSuccess: {//成功

   }
    break;
  }
 }
 elseif ([response isKindOfClass:WBAuthorizeResponse.class])
 {
  if (0 == response.statusCode) {
   //授权成功
  }
  else {
   //授权失败
  }
 }
}
- (void)recvNotificationData:(NSNotification *)notification {
 NSString *sName = notification.name;
 if ([sName isEqualToString:@"Auth"]) {
  //sina 的授权请求--》新浪微博客户端和网页版通用的命令
  /*
   新浪微博客户端,就是sso,通过新浪微博客户端授权和发布微博内容
   网页版,就是组合命令直接发送到新浪微博服务端。
   */
  WBAuthorizeRequest *request = [WBAuthorizeRequestrequest];
  request.redirectURI = sinaAppURL;
  request.scope = @"all";
  [WeiboSDK sendRequest:request];
 }
 else if ([sNameisEqualToString:@"Data"]) {
  if ([WeiboSDKisWeiboAppInstalled])
  {
   //安装了新浪微博客户端
   WBMessageObject *message = [WBMessageObjectmessage];
   message.text = @"文本";
   WBImageObject *image = [WBImageObjectobject];
   image.imageData = @"图片";//jpeg格式的图片,为NSData形式
   message.imageObject = image;
   WBSendMessageToWeiboRequest *request = [WBSendMessageToWeiboRequestrequestWithMessage:message];
   [WeiboSDK sendRequest:request];
  }
  else {
   BOOL bText = YES;
   if (bText) {
    NSMutableDictionary* parameters = [NSMutableDictionarydictionary];
    [parameters setObject:@"文本"forKey:@"status"];
    [WBHttpRequestrequestWithAccessToken:sinaAccessTokenurl:[NSStringstringWithFormat:@"%@",@"https://api.weibo.com/2/statuses/update.json"]httpMethod:@"POST"params:parametersdelegate:selfwithTag:@"1"];
   }
   else {
    NSMutableDictionary* parameters = [NSMutableDictionarydictionary];
    [parameters setObject:@"文本"forKey:@"status"];
    [parameters setObject:@"图片"forKey:@"pic"]; //jpeg的 NSData 格式,
    [WBHttpRequestrequestWithAccessToken:sinaAccessTokenurl:[NSStringstringWithFormat:@"%@",@"https://api.weibo.com/2/statuses/upload.json"]httpMethod:@"POST"params:parametersdelegate:selfwithTag:[NSStringstringWithFormat:@"1"]];
   }
  }
 }
 else if ([sNameisEqualToString:@"LogOut"]) {
  [WeiboSDK logOutWithToken:sinaAccessTokendelegate:selfwithTag:@"1"];
 }
}

#pragma Mark WBHttpRequestDelegate
- (void)request:(WBHttpRequest *)request didFailWithError:(NSError *)error {
 //发布失败
}
- (void)request:(WBHttpRequest *)request didFinishLoadingWithResult:(NSString *)result {
 //发布成功
}

腾讯的实现方式和新浪的不一样。下面是腾讯的调用方式

// MyViewController.h
#import "WeiboApi.h"
@interface MyViewController :UIViewController<WeiboAuthDelegate,WeiboRequestDelegate> {
}
@property(nonatomic,retain)WeiboApi   *qqwb;
@end
// MyViewController.m
#import "AppDelegate.h"
- (void)viewDidLoad
{
 [superviewDidLoad];
 AppDelegate *delegate = (AppDelegate*)[UIApplicationsharedApplication].delegate;
 if (nil != delegate.qqwbAppDelete) {
  self.qqwb = delegate.qqwbAppDelete;
 }
 else {
  self.qqwb = [[WeiboApialloc]initWithAppKey:qqAppKeyandSecret:qqAppSecretandRedirectUri:qqAppURL];
  delegate.qqwbAppDelete = _qqwb;
 }
}
- (void)buttonAction:(id)sender {
 UIButton *button = (UIButton *)sender;
 if (0 == button.tag) {
  //新浪
  [selfsendAuthWithType:0];
 }
 else {
  //腾讯
  [selfsendAuthWithType:1];
 }
}
- (void)sendAuthWithType:(NSInteger)aIndex {
 if (0 == aIndex) {
  if ([self isAuthValid]) {
   //显示内容界面
  }
  else {
   [[NSNotificationCenterdefaultCenter] postNotificationName:@"Auth"object:nil];
  }
 }
 else {
  if ([self isAuthValid]) {
   //显示内容界面
  }
  else {
   [_qqwb loginWithDelegate:selfandRootController:self];
  }
 }
}

- (void)sendDataWithPic:(NSString *)sText ImageData:(NSData *)aImageData {
 NSMutableDictionary* parameters = [NSMutableDictionarydictionary];
 [parameters setObject:@"xml"forKey:@"format"];
 [parameters setObject:sText forKey:@"content"];
 [parameters setObject:aImageData forKey:@"pic"];
 [_qqwb requestWithParams:parameters
      apiName:[NSStringstringWithFormat:@"%@",@"t/add_pic"]
     httpMethod:@"POST"delegate:self];
}

- (void)sendText:(NSString *)sText {
 NSMutableDictionary* parameters = [NSMutableDictionarydictionary];
 [parameters setObject:@"xml"forKey:@"format"];
 [parameters setObject:sText forKey:@"content"];
 [_qqwb requestWithParams:parameters
      apiName:[NSStringstringWithFormat:@"%@",@"t/add"]
     httpMethod:@"POST"delegate:self];
}

#pragma Mark WeiboAuthDelegate
- (void)DidAuthFinished:(WeiboApi *)wbapi {
 //授权成功,后显示内容界面
}

#pragma Mark WeiboRequestDelegate
- (void)didReceiveRawData:(NSData *)data reqNo:(int)reqno {
 //发布成功
}
- (void)didFailWithError:(NSError *)error reqNo:(int)reqno {
 //发布失败
}
//以下是处理sina的授权验证函数,qq的未写。
- (void)removeAuthData
{
 self.sinaid = nil;
 self.sinatoken =nil;
 self.sinadate =nil;
}
- (BOOL)isLoggedIn
{
 returnsinaid && sinatoken && sinadate;
}
- (BOOL)isAuthorizeExpired
{
 NSDate *now = [NSDatedate];
 /*if (0 == bSina) {*/
  return ([nowcompare:sinadate] ==NSOrderedDescending);
 //}
 /*else {
  AppDelegate *delegate = (AppDelegate*)[UIApplication sharedApplication].delegate;
  return [delegate.qqwbAppDelete isAuthorizeExpired];
 }*/
}
- (BOOL)isAuthValid
{
 return ([selfisLoggedIn] && ![selfisAuthorizeExpired]);
}

以下是网上资源
新浪:
http://www.jb51.net/article/98044.htm

腾讯:
https://github.com/heloyue/TCWeiboSDK-LightVersion

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • iOS仿微博客户端一条微博的展示效果

    前言 做一个微博客户端的第三方是自学的第一个实践的项目,自从从事iOS工作之后,就把这个项目给搁置了.趁现在过年回来有些空闲时间,再次修改(总觉得项目就是不停地修改).并且记录一点东西,以后可再回头看看从前走过的路,挖过的坑.这是一条微博的展示,不是整个项目. 废话不多说,先上效果图: 拆分控件 在开始动手写代码之前,我们得先确定怎么去实现这样子的布局,也就是分析需要用到哪些控件. 观察微博客户端,整体是可滑动的,而且界面展示比较规律的,所以应该是使用UITableView实现的.那么一条微博应

  • 完整的iOS新浪微博分享功能开发

    本文实例为大家分享了Android九宫格图片展示的具体代码,供大家参考,具体内容如下 做新浪分享 需先去http://open.weibo.com/apps注册开发者app 很简单! 第1步 第2步 3 设置你的应用的信息 找到自己的appkey 还需要设置自己的kAppRedirectURL测试可以随便写个! 开发部分在下面ios新浪微博分享(2)这部分: 开发需要下载官方的sdkhttp://open.weibo.com/wiki/SDK#iOS_SDK 本人下载的版本 新建一个viewco

  • iOS仿微博图片浏览器

    KNPhotoBrower 高仿微博图片浏览器 PhotoBrower.gif 一.功能描述及要点 1.加载网络九宫格图片,collectionView,scrollView 2.SDWebImage下载图片,KNProgressHUD显示加载进度 3.高仿微博,显示动画,KNToast提示 二.方法调用 1.创建KNPhotoBrower,并传入相应的参数 // 每一个图片控件对象, 对一一对应 KNPhotoItems ,再将多个KNPhotoItems 对象放入数组 KNPhotoItem

  • iOS中使用UItableviewcell实现团购和微博界面的示例

    使用xib自定义UItableviewcell实现一个简单的团购应用界面布局 一.项目文件结构和plist文件 二.实现效果 三.代码示例 1.没有使用配套的类,而是直接使用xib文件控件tag值操作 数据模型部分: YYtg.h文件 复制代码 代码如下: // //  YYtg.h //  01-团购数据显示(没有配套的类) // //  Created by apple on 14-5-29. //  Copyright (c) 2014年 itcase. All rights reserv

  • iOS开发之路--微博OAuth授权_取得用户授权的accessToken

    最终效果图: OauthViewController.m // // OauthViewController.m // 20_帅哥no微博 // // Created by beyond on 14-8-5. // Copyright (c) 2014年 com.beyond. All rights reserved. // 授权控制器,仅运行一次,取得了当前用户的access_token和uid之后,存档,切换窗口的主控制器 #import "OauthViewController.h&quo

  • iOS 仿微博客户端红包加载界面 XLDotLoading效果

    一.显示效果 二.原理简介 1.思路 要实现这个效果需要先知道这两个硬币是怎样运动的,然后通过放大.缩小的效果实现的这种有距离感的效果.思路如下: 一.这两个硬币是在一定范围内做相对运动的,可以先使一个硬币在一个固定范围内做左右的往复运动,另一个硬币和它做"相对运动"即可. 二.让硬币从左至右移动时先变小再回复正常:从右至左移动时先变大再回复正常:这样就实现了这用有距离感的"相对运动". 2.代码 第一步 要实现一个硬币在一定范围内实现左右往复运动,需要先固定一个范

  • iOS开发之路--微博骨架搭建

    最终效果图: BeyondViewController.m // // BeyondViewController.m // 20_帅哥no微博 // // Created by beyond on 14-8-3. // Copyright (c) 2014年 com.beyond. All rights reserved. // 这个就是主控制器,分为两块,下面是Dock栏,上面是显示不同的子控制器的view,子控制器最好用导航控制器包装一下,这样子控制器就自带了导航条,左按钮,标题,右按钮 /

  • iOS开发之路--微博“更多”页面

    最终效果图: MoreViewController.m // // MoreViewController.m // 20_帅哥no微博 // // Created by beyond on 14-8-4. // Copyright (c) 2014年 com.beyond. All rights reserved. // #import "MoreViewController.h" @interface MoreViewController () { // more.plist根是字典

  • iOS开发之路--微博新特性页面

    BeyondAppDelegate.m // // BeyondAppDelegate.m // 20_帅哥no微博 // // Created by beyond on 14-8-3. // Copyright (c) 2014年 com.beyond. All rights reserved. // #import "BeyondAppDelegate.h" #import "BeyondViewController.h" #import "NewFe

  • iOS新浪微博、腾讯微博分享功能实例

    一个是新浪微博,腾讯微博的分享按钮,一个是他们的绑定情况(其实就是是否授权).点击微博分享中新浪或腾讯按钮,就进行相应的授权(若没授权),显示微博内容,而后发布微博.设置界面中的绑定,就是相关的应用授权. 呵呵,其实也蛮简单滴. 首先分别从新浪微博开放平台(http://open.weibo.com/).腾讯微博开放平台(http://dev.t.qq.com/)中注册应用,获取到Appkey,AppSecret和AppURL(其中 AppURL是要自己填写的). 然后分别下载相关的SDK. h

  • Android实现短信、微信、微博分享功能

    在纠结了几天的图表功能之后,我开始开发一个新的功能.即分享内容到短信.微信.微博等渠道,对应的我有一个简单的 Task: 在 Toolbar 写分享的按钮 绘制一个 Android 的分享页面 编写短信分享示例 编写社交分享 在这一天,我只完成了前面的三部分. Toolbar 上的分享按钮 在 Toolbar 主要还是靠 ImageView 来绘制右上角的分享按钮: <?xml version="1.0" encoding="utf-8"?> <a

  • vue单应用在ios系统中实现微信分享功能操作

    表示是第一次使用vue做单应用显目,也是在逐渐的摸索中~更是各种踩坑,各种填坑,打算写博客么?是因为不想写笔记了,嗯嗯 就是这么简单 进入正题. 刚开始做微信分享的这个功能的时候,脑补了官方文档微信JS-SDK说明文档 基础的知识不多说了,反正多看文档总是没错的~在安卓系统上面分享是没出错的,但是在ios上面问题就来了,表示无限吐槽ios,但是吐槽归吐槽,问题总是该解决的-在网上百度了很多vue单应用在ios系统中实现微信分享失败的原因以及解决方案 原因 单页面应用通过什么入口进去的 url保持

  • 微信JS-SDK自定义分享功能实例详解【分享给朋友/分享到朋友圈】

    本文实例讲述了微信JS-SDK自定义分享功能.分享给大家供大家参考,具体如下: 分享出去的内容,可以通过jssdk进行修改. 1.配置jssdk Wx_config.html <?php import("@.ORG.jssdk"); $jssdk = new JSSDK(C('oauth_config.appid'), C('oauth_config.appsecret')); $signPackage = $jssdk->GetSignPackage(); ?> &

  • Android开发中应用程序分享功能实例

    本文实例讲述了Android开发中应用程序分享功能.分享给大家供大家参考,具体如下: Intent shareIntent = new Intent(); shareIntent.setAction(Intent.ACTION_SEND); //设置类型 shareIntent.setType("text/plain"); //设置分享的主题 shareIntent.putExtra("android.intent.extra.SUBJECT", "分享&

  • Android调用系统自带的分享功能实例代码

    实现分享功能的几个办法 1.调用系统的分享功能 2.通过第三方SDK,如ShareSDK,友盟等 3.自行使用各自平台的SDK,比如QQ,微信,微博各自的SDK 这里就记录下第一种办法. 分享文本信息 Intent textIntent = new Intent(Intent.ACTION_SEND); textIntent.setType("text/plain"); textIntent.putExtra(Intent.EXTRA_TEXT, "这是一段分享的文字&quo

  • vue中进行微博分享的实例讲解

    1.首先要在页面写出点击可进行微博分享的入口,样式因自己项目而定: <li class="bottomIcon_5 shareSina"><a href="javascript:;" rel="external nofollow" target="_blank"></a><div class="shareTxt">微博</div></li&g

  • java实现的新浪微博分享代码实例

    weibo.java 复制代码 代码如下: @Override         protected void onCreate(Bundle savedInstanceState) {                  super.onCreate(savedInstanceState);                  setContentView(R.layout.user_center);                  // 创建微博实例                 mWeibo

  • React Native第三方平台分享的实例(Android,IOS双平台)

    本文主要介绍了React Native第三方平台分享的实例(Android,IOS双平台),分享给大家,具体如下: 源码已开源到Github,地址请点击:react-native-share[一行代码,双平台分享] 目前支持分享的平台有[QQ][QQ空间][微信][朋友圈][微博][FaceBook]  欢迎大家star,fork..... [ Android平台配置 ] 1. app目录下创建 libs 文件夹,添加依赖文件[直接复制源码中 libs 目录即可] 2. app / src /

随机推荐