新浪微博客户端开发之OAuth认证篇

2. /OauthTest/src/com/weibo/sdk/android/demo/MainActivity.java

package com.weibo.sdk.android.demo;

import java.text.SimpleDateFormat;

import java.util.Date;

import android.app.Activity;

import android.os.Bundle;

import android.view.View;

import android.view.View.OnClickListener;

import android.widget.Button;

import android.widget.TextView;

import android.widget.Toast;

import com.weibo.sdk.android.Oauth2AccessToken;

import com.weibo.sdk.android.Weibo;

import com.weibo.sdk.android.WeiboAuthListener;

import com.weibo.sdk.android.WeiboDialogError;

import com.weibo.sdk.android.WeiboException;

import com.weibo.sdk.android.keep.AccessTokenKeeper;

public class MainActivity extends Activity {

private Weibo mWeibo; //Weibo引用对象

public static Oauth2AccessToken accessToken; //访问token

private Button oauthBtn;

private TextView mText;

@Override

public void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

setContentView(R.layout.activity_main);

//获取Weibo引用对象,传入appkey和回调url

mWeibo = Weibo.getInstance(ConstantS.APP_KEY, ConstantS.REDIRECT_URL);

mText = (TextView) findViewById(R.id.show);

oauthBtn = (Button) findViewById(R.id.oauthBtn);

MainActivity.accessToken = AccessTokenKeeper.readAccessToken(this);

oauthBtn.setOnClickListener(new OnClickListener() {

@Override

public void onClick(View v) {

mWeibo.authorize(MainActivity.this, new AuthDialogListener());

}

});

}

public class AuthDialogListener implements WeiboAuthListener {

@Override

public void onCancel() {

//Oauth2.0认证过程中,如果认证窗口被关闭或认证取消时调用

Toast.makeText(getApplicationContext(), “Auth cancel” , Toast.LENGTH_LONG).show();

}

@Override

public void onComplete(Bundle values) {

// 认证结束后调用此方法

String token = values.getString(“access_token”);// 表明用户身份的token,用于微博API的调用

String expires_in = values.getString(“expires_in”);// 过期时间,用于判断登录是否过程

System.out.println(expires_in);

MainActivity.accessToken = new Oauth2AccessToken(token, expires_in);

String date = new SimpleDateFormat(“yyyy/MM/dd HH:mm:ss”)

.format(new java.util.Date(MainActivity.accessToken

.getExpiresTime()));

mText.setText("认证成功: \r\n access_token: " + token + “\r\n”

  • "expires_in: " + expires_in + “\r\n有效期:” + date);

AccessTokenKeeper.keepAccessToken(MainActivity.this, accessToken);

Toast.makeText(MainActivity.this, “认证成功”, Toast.LENGTH_SHORT)

.show();

}

@Override

public void onError(WeiboDialogError e) {

//Oauth2.0认证过程中,当认证对话框中的webView接收数据出现错误时调用此方法

Toast.makeText(getApplicationContext(), “Auth error:” + e.getMessage(), Toast.LENGTH_LONG).show();

}

@Override

public void onWeiboException(WeiboException e) {

//当认证过程中捕获到WeiboException时调用

Toast.makeText(getApplicationContext(), “Auth exception:” + e.getMessage(), Toast.LENGTH_LONG).show();

}

}

}

package com.weibo.sdk.android.demo;

/**

  • 定义一个常量接口,方便管理常量

  • @author wwj

*/

public interface ConstantS {

// 应用的key请到官方申请正式的appkey替换APP_KEY

public static final String APP_KEY = “249239496”;

// 替换为开发者REDIRECT_URL

public static final String REDIRECT_URL = “http://www.sina.com”;

// 新支持scope,支持传入多个scope权限,用逗号分隔

public static final String SCOPE = “email,direct_messages_read,direct_messages_write,” +

“friendships_groups_read,friendships_groups_write,statuses_to_me_read,” +

“follow_app_official_microblog”;

}

原本SCOPE是要用在新版的SDK中,这是新增的一个参数

方法声明是这样的:

public static Weibo getInstance(java.lang.String appKey,

java.lang.String redirectUrl,

java.lang.String aScope)

微博初始化函数,需要优先其他函数调用.如果appKey或redirectUrl为空,默认抛出RuntimeException

参数:

appKey - 第三方应用的appkey

redirectUrl - 第三方应用的回调页

返回:

Weibo的实例

抛出:

java.lang.RuntimeException

4./OauthTest/src/com/weibo/sdk/android/keep/AccessTokenKeeper.java

package com.weibo.sdk.android.keep;

import android.content.Context;

import android.content.SharedPreferences;

import android.content.SharedPreferences.Editor;

import com.weibo.sdk.android.Oauth2AccessToken;

/**

  • 该类用于保存Oauth2AccessToken到sharepreference,并提供读取功能

  • @author wwj

*/

public class AccessTokenKeeper {

private static final String PREFERENCES_NAME = “com_weibo_sdk_android”;

/**

  • 保存accsssToken到SharedPreferences

  • @param context 上下文对象

  • @param token Oauth2AccessToken

*/

public static void keepAccessToken(Context context, Oauth2AccessToken token) {

SharedPreferences pref = context.getSharedPreferences(PREFERENCES_NAME, Context.MODE_APPEND);

Editor editor = pref.edit();

editor.putString(“token”, token.getToken());

editor.putLong(“expiresTime”, token.getExpiresTime());

editor.commit();

}

/**

  • 清空sharedPreferences

  • @param context

*/

public static void clear(Context context) {

SharedPreferences pref = context.getSharedPreferences(PREFERENCES_NAME, Context.MODE_APPEND);

Editor editor = pref.edit();

editor.clear();

editor.commit();

}

/**

  • 从SharedPreferences读取accessToken

  • @param context

  • @return Oauth2AccessToken

*/

public static Oauth2AccessToken readAccessToken(Context context) {

Oauth2AccessToken token = new Oauth2AccessToken();

SharedPreferences pref = context.getSharedPreferences(PREFERENCES_NAME, Context.MODE_APPEND);

token.setToken(pref.getString(“token”, “”));

token.setExpiresTime(pref.getLong(“expiresTime”, 0));

return token;

}

}

以上就是简单的实现了第三方程序访问用户微博授权,没有太复杂的地方,主要是为了熟悉新浪微博的授权过程。

2014年5月19日 补充

很多初学者在使用新浪的时候要不就是无法调取授权界面,要不就是无法获得accesstoken.在这篇博客我重新补充一点,方便童鞋们在使用别人开发的客户端遇到的这些疑惑得到解答。

来到新浪开放平台,你首先需要创建相应的应用,Android的就创建“移动应用”

下面是列出的几个要点:

1.创建应用如何填写包名和签名

首先你要保证你使用的客户端跟你创建的应用的包名是一致的,还需要用签名工具(注:签名工具在你下载的SDK压缩包下,解压之后会可以看到app_signatures.apk文件)生成相应的签名,下面是笔者需要改的包名和相应的app key、app secret,读者需要改成对应自己项目的包名和授权的appkey。
先自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数初中级Android工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则近万的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《Android移动开发全套学习资料》送给大家,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。

img

img

img

img

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频

如果你觉得这些内容对你有帮助,可以扫码领取!!!!

学习福利

【Android 详细知识点思维脑图(技能树)】

其实Android开发的知识点就那么多,面试问来问去还是那么点东西。所以面试没有其他的诀窍,只看你对这些知识点准备的充分程度。so,出去面试时先看看自己复习到了哪个阶段就好。

虽然 Android 没有前几年火热了,已经过去了会四大组件就能找到高薪职位的时代了。这只能说明 Android 中级以下的岗位饱和了,现在高级工程师还是比较缺少的,很多高级职位给的薪资真的特别高(钱多也不一定能找到合适的),所以努力让自己成为高级工程师才是最重要的。

这里附上上述的面试题相关的几十套字节跳动,京东,小米,腾讯、头条、阿里、美团等公司19年的面试题。把技术点整理成了视频和PDF(实际上比预期多花了不少精力),包含知识脉络 + 诸多细节。

由于篇幅有限,这里以图片的形式给大家展示一小部分。

网上学习 Android的资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。希望这份系统化的技术体系对大家有一个方向参考。
《Android学习笔记总结+移动架构视频+大厂面试真题+项目实战源码》点击传送门,即可免费领取!

自己复习到了哪个阶段就好。

虽然 Android 没有前几年火热了,已经过去了会四大组件就能找到高薪职位的时代了。这只能说明 Android 中级以下的岗位饱和了,现在高级工程师还是比较缺少的,很多高级职位给的薪资真的特别高(钱多也不一定能找到合适的),所以努力让自己成为高级工程师才是最重要的。

这里附上上述的面试题相关的几十套字节跳动,京东,小米,腾讯、头条、阿里、美团等公司19年的面试题。把技术点整理成了视频和PDF(实际上比预期多花了不少精力),包含知识脉络 + 诸多细节。

由于篇幅有限,这里以图片的形式给大家展示一小部分。

[外链图片转存中…(img-LlVQgV0g-1711295465995)]

网上学习 Android的资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。希望这份系统化的技术体系对大家有一个方向参考。
《Android学习笔记总结+移动架构视频+大厂面试真题+项目实战源码》点击传送门,即可免费领取!

  • 12
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值