免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 1880 | 回复: 2
打印 上一主题 下一主题

[Android] 新浪微博分享实例代码 [复制链接]

论坛徽章:
1
操作系统版块每日发帖之星
日期:2015-07-07 22:20:00
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2015-07-06 14:29 |只看该作者 |倒序浏览
weibo.java
  1. @Override
  2.         protected void onCreate(Bundle savedInstanceState) {
  3.                  super.onCreate(savedInstanceState);
  4.                  setContentView(R.layout.user_center);
  5.                  // 创建微博实例
  6.                 mWeiboAuth = new WeiboAuth(this, Constants.APP_KEY,
  7.                                  Constants.REDIRECT_URL, Constants.SCOPE);
  8.                  // 创建微博分享接口实例
  9.                 mWeiboShareAPI = WeiboShareSDK.createWeiboAPI(this, Constants.APP_KEY);

  10.                  // 当 Activity 被重新初始化时(该 Activity 处于后台时,可能会由于内存不足被杀掉了),
  11.                 // 需要调用 {@link IWeiboShareAPI#handleWeiboResponse} 来接收微博客户端返回的数据。
  12.                 // 执行成功,返回 true,并调用 {@link IWeiboHandler.Response#onResponse};
  13.                 // 失败返回 false,不调用上述回调
  14.                 if (savedInstanceState != null) {
  15.                          mWeiboShareAPI.handleWeiboResponse(getIntent(), this);
  16.                  }
  17.         }

  18. /**
  19.           * 检查用户是否安装新浪微博
  20.          */
  21.          public void isNotInstall() {
  22.                  try {
  23.                          // 检查微博客户端环境是否正常,如果未安装微博,弹出对话框询问用户下载微博客户端
  24.                         if (mWeiboShareAPI.checkEnvironment(true)) {

  25.                                  // 注册第三方应用 到微博客户端中,注册成功后该应用将显示在微博的应用列表中。
  26.                                 // 但该附件栏集成分享权限需要合作申请,详情请查看 Demo 提示
  27.                                 mWeiboShareAPI.registerApp();
  28.                                 startSinaShare();
  29.                          }
  30.                  } catch (WeiboShareException e) {
  31.                          e.printStackTrace();
  32.                          Toast.makeText(UserCenter.this, e.getMessage(), Toast.LENGTH_LONG)
  33.                                          .show();
  34.                  }
  35.                  if (dialog != null) {
  36.                          dialog.dismiss();
  37.                  }
  38.          }

  39.          /**
  40.           * 微博认证授权回调类。 1. SSO 授权时,需要在 {@link #onActivityResult} 中调用
  41.          * {@link SsoHandler#authorizeCallBack} 后, 该回调才会被执行。 2. 非 SSO
  42.           * 授权时,当授权结束后,该回调就会被执行。 当授权成功后,请保存该 access_token、expires_in、uid 等信息到
  43.          * SharedPreferences 中。
  44.          */
  45.          class AuthListener implements WeiboAuthListener {

  46.                  @Override
  47.                  public void onComplete(Bundle values) {
  48.                          // 从 Bundle 中解析 Token
  49.                          mAccessToken = Oauth2AccessToken.parseAccessToken(values);
  50.                          if (mAccessToken.isSessionValid()) {
  51.                                  // 保存 Token 到 SharedPreferences
  52.                                  AccessTokenKeeper.writeAccessToken(UserCenter.this,
  53.                                                  mAccessToken);
  54.                                  sendMessage();
  55.                          }
  56.                  }

  57.                  @Override
  58.                  public void onCancel() {
  59.                  }

  60.                  @Override
  61.                  public void onWeiboException(WeiboException e) {
  62.                          Toast.makeText(UserCenter.this,
  63.                                          "Auth exception : " + e.getMessage(), Toast.LENGTH_LONG)
  64.                                          .show();
  65.                  }
  66.          }

  67.          /**
  68.           * 新浪微博用户授权
  69.          */
  70.          public void startSinaShare() {
  71.                  mSsoHandler = new SsoHandler(UserCenter.this, mWeiboAuth);

  72.                  // 从 SharedPreferences 中读取上次已保存好 AccessToken 等信息,
  73.                 mAccessToken = AccessTokenKeeper.readAccessToken(this);

  74.                  // 如果Token有效,则直接调用发送微博
  75.                 if (mAccessToken.isSessionValid()) {
  76.                          sendMessage();
  77.                  } else {
  78.                          mSsoHandler.authorize(new AuthListener());
  79.                  }
  80.          }

  81.          /**
  82.           * @See {@link Activity#onNewIntent}
  83.           */
  84.          @Override
  85.          protected void onNewIntent(Intent intent) {
  86.                  super.onNewIntent(intent);

  87.                  // 从当前应用唤起微博并进行分享后,返回到当前应用时,需要在此处调用该函数
  88.                 // 来接收微博客户端返回的数据;执行成功,返回 true,并调用
  89.                 // {@link IWeiboHandler.Response#onResponse};失败返回 false,不调用上述回调
  90.                 mWeiboShareAPI.handleWeiboResponse(intent, this);
  91.          }

  92.          /**
  93.           * 当 SSO 授权 Activity 退出时,该函数被调用。
  94.          *
  95.           * @see {@link Activity#onActivityResult}
  96.           */
  97.          @Override
  98.          protected void onActivityResult(int requestCode, int resultCode, Intent data) {
  99.                  super.onActivityResult(requestCode, resultCode, data);
  100.                  // SSO 授权回调
  101.                 // 重要:发起 SSO 登陆的 Activity 必须重写 onActivityResult
  102.                  if (mSsoHandler != null) {
  103.                          mSsoHandler.authorizeCallBack(requestCode, resultCode, data);
  104.                  }
  105.          }

  106.          /**
  107.           * 接收微客户端博请求的数据。 当微博客户端唤起当前应用并进行分享时,该方法被调用。
  108.          *
  109.           * @param baseRequest
  110.           *            微博请求数据对象
  111.          * @see {@link IWeiboShareAPI#handleWeiboRequest}
  112.           */
  113.          @Override
  114.          public void onResponse(BaseResponse baseResp) {
  115.                  switch (baseResp.errCode) {
  116.                  case WBConstants.ErrorCode.ERR_OK:
  117.                          if (PublicFun.shareCondition()) {
  118.                                  gainBoBi();
  119.                          } else {
  120.                                  Toast.makeText(this, R.string.share_success, Toast.LENGTH_LONG)
  121.                                                  .show();
  122.                          }
  123.                          break;
  124.                  case WBConstants.ErrorCode.ERR_CANCEL:
  125.                          break;
  126.                  case WBConstants.ErrorCode.ERR_FAIL:
  127.                          Toast.makeText(this, R.string.errcode_deny, Toast.LENGTH_LONG)
  128.                                          .show();
  129.                          break;
  130.                  }
  131.                  if (dialog != null) {
  132.                          dialog.dismiss();
  133.                  }
  134.          }

  135.          /**
  136.           * 第三方应用发送请求消息到微博,唤起微博分享界面。
  137.           * @see {@link #sendMultiMessage} 或者 {@link #sendSingleMessage}
  138.           */
  139.          private void sendMessage() {
  140.                  if (mWeiboShareAPI.isWeiboAppSupportAPI()) {
  141.                          sendMultiMessage();
  142.                  } else {
  143.                          Toast.makeText(this, R.string.sina_share_hint, Toast.LENGTH_SHORT)
  144.                                          .show();
  145.                  }
  146.          }

  147.          /**
  148.           * 第三方应用发送请求消息到微博,唤起微博分享界面。 注意:当
  149.          * {@link IWeiboShareAPI#getWeiboAppSupportAPI()} >= 10351 时,支持同时分享多条消息,
  150.          *
  151.           * @param hasText
  152.           *            分享的内容是否有文本
  153.          * @param hasImage
  154.           *            分享的内容是否有图片
  155.          * @param hasWebpage
  156.           *            分享的内容是否有网页
  157.          */
  158.          private void sendMultiMessage() {
  159.                  // 1. 初始化微博的分享消息
  160.                 WeiboMultiMessage weiboMessage = new WeiboMultiMessage();
  161.                  weiboMessage.textObject = getTextObj();
  162.                  // 用户可以分享其它媒体资源(网页、音乐、视频、声音中的一种)
  163.                 weiboMessage.mediaObject = getWebpageObj();
  164.                  // 2. 初始化从第三方到微博的消息请求
  165.                 SendMultiMessageToWeiboRequest request = new SendMultiMessageToWeiboRequest();
  166.                  // 用transaction唯一标识一个请求
  167.                 request.transaction = String.valueOf(System.currentTimeMillis());
  168.                  request.multiMessage = weiboMessage;

  169.                  // 3. 发送请求消息到微博,唤起微博分享界面
  170.                 mWeiboShareAPI.sendRequest(request);

  171.                  // 记录分享日志
  172.                 PublicFun.sendShareAppLog(UserCenter.this,
  173.                                  getResources().getString(R.string.micro_blog));
  174.                  if (dialog != null) {
  175.                          dialog.dismiss();
  176.                  }
  177.          }

  178.          /**
  179.           * 创建文本消息对象。
  180.           * @return 文本消息对象。
  181.          */
  182.          private TextObject getTextObj() {
  183.                  TextObject textObject = new TextObject();
  184.                  textObject.text = getResources().getString(R.string.share_content);
  185.                  return textObject;
  186.          }

  187.          /**
  188.           * 创建多媒体(网页)消息对象。
  189.           * @return 多媒体(网页)消息对象。
  190.          */
  191.          private WebpageObject getWebpageObj() {
  192.                  WebpageObject mediaObject = new WebpageObject();
  193.                  mediaObject.actionUrl = getString(R.string.share_url);
  194.                  mediaObject.identify = Utility.generateGUID();
  195.                  mediaObject.title = getResources().getString(R.string.share_title);
  196.                  mediaObject.description = getString(R.string.share_content);
  197.                  Bitmap bmp = BitmapFactory.decodeResource(getResources(),
  198.                                  R.drawable.icon);
  199.                  mediaObject.setThumbImage(bmp);
  200.                  return mediaObject;
  201.          }


  202. /**
  203. * 该类定义了微博授权时所需要的参数。
  204. * @author SINA
  205. * @SINCE 2013-10-07
  206. */
  207. public class AccessTokenKeeper {
  208.      private static final String PREFERENCES_NAME = "com_weibo_sdk_android";

  209.      private static final String KEY_UID           = "uid";
  210.      private static final String KEY_ACCESS_TOKEN  = "access_token";
  211.      private static final String KEY_EXPIRES_IN    = "expires_in";

  212.      /**
  213.       * 保存 Token 对象到 SharedPreferences。
  214.      *
  215.       * @param context 应用程序上下文环境
  216.      * @param token   Token 对象
  217.      */
  218.      public static void writeAccessToken(Context context, Oauth2AccessToken token) {
  219.          if (null == context || null == token) {
  220.              return;
  221.          }
  222.          SharedPreferences pref = context.getSharedPreferences(PREFERENCES_NAME, Context.MODE_APPEND);
  223.          Editor editor = pref.edit();
  224.          editor.putString(KEY_UID, token.getUid());
  225.          editor.putString(KEY_ACCESS_TOKEN, token.getToken());
  226.          editor.putLong(KEY_EXPIRES_IN, token.getExpiresTime());
  227.          editor.commit();

  228.      }

  229.      /**
  230.       * 从 SharedPreferences 读取 Token 信息。
  231.      *
  232.       * @param context 应用程序上下文环境
  233.      *
  234.       * @return 返回 Token 对象
  235.      */
  236.      public static Oauth2AccessToken readAccessToken(Context context) {
  237.          if (null == context) {
  238.              return null;
  239.          }

  240.          Oauth2AccessToken token = new Oauth2AccessToken();
  241.          SharedPreferences pref = context.getSharedPreferences(PREFERENCES_NAME, Context.MODE_APPEND);
  242.          token.setUid(pref.getString(KEY_UID, ""));
  243.          token.setToken(pref.getString(KEY_ACCESS_TOKEN, ""));
  244.          token.setExpiresTime(pref.getLong(KEY_EXPIRES_IN, 0));

  245.          return token;
  246.      }

  247.      /**
  248.       * 清空 SharedPreferences 中 Token信息。
  249.      *
  250.       * @param context 应用程序上下文环境
  251.      */
  252.      public static void clear(Context context) {
  253.          if (null == context) {
  254.              return;
  255.          }
  256.          SharedPreferences pref = context.getSharedPreferences(PREFERENCES_NAME, Context.MODE_APPEND);
  257.          Editor editor = pref.edit();
  258.          editor.clear();
  259.          editor.commit();
  260.      }
  261. }
复制代码

论坛徽章:
59
2015七夕节徽章
日期:2015-08-24 11:17:25ChinaUnix专家徽章
日期:2015-07-20 09:19:30每周论坛发贴之星
日期:2015-07-20 09:19:42ChinaUnix元老
日期:2015-07-20 11:04:38荣誉版主
日期:2015-07-20 11:05:19巳蛇
日期:2015-07-20 11:05:26CU十二周年纪念徽章
日期:2015-07-20 11:05:27IT运维版块每日发帖之星
日期:2015-07-20 11:05:34操作系统版块每日发帖之星
日期:2015-07-20 11:05:36程序设计版块每日发帖之星
日期:2015-07-20 11:05:40数据库技术版块每日发帖之星
日期:2015-07-20 11:05:432015年辞旧岁徽章
日期:2015-07-20 11:05:44
2 [报告]
发表于 2015-07-11 20:56 |只看该作者
谢谢分享。

论坛徽章:
80
20周年集字徽章-庆
日期:2020-10-28 14:09:1215-16赛季CBA联赛之北京
日期:2020-10-28 13:32:5315-16赛季CBA联赛之北控
日期:2020-10-28 13:32:4815-16赛季CBA联赛之天津
日期:2020-10-28 13:13:35黑曼巴
日期:2020-10-28 12:29:1520周年集字徽章-周	
日期:2020-10-31 15:10:0720周年集字徽章-20	
日期:2020-10-31 15:10:07ChinaUnix元老
日期:2015-09-29 11:56:3020周年集字徽章-年
日期:2020-10-28 14:14:56
3 [报告]
发表于 2015-07-15 09:59 |只看该作者
我们的项目一直使用的是umeng的社会化组件 感觉还是很方便的。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP