`
yuanlanjun
  • 浏览: 1185968 次
文章分类
社区版块
存档分类
最新评论

新浪微博客户端 -- OAuth认证

阅读更多


OAuth的基本概念,OAUTH协议为用户资源的授权提供了一个安全的、开放而又简易的标准。与以往的授权方式不同之处是OAUTH的授权不会使第三方触及到用户的帐号信息(如用户名与密码),即第三方无需使用用户的用户名与密码就可以申请获得该用户资源的授权,因此OAUTH是安全的。同样新浪微博提供OAuth认证也是为了保证用户账号和密码的安全,在这里通过OAuth建立普通新浪微博用户、客户端程序(我们正在开发的这个android客户端程序)、新浪微博三者之间的相互信任关系,让客户端程序(我们正在开发的这个android客户端程序)不需要知道用户的账号和密码也能浏览、发布微博,这样有效的保护了用户账号的安全性不需要把账号密码透露给客户端程序又达到了通过客户端程序写微博看微博目的。这个是OAuth的作用。

结合新浪微博的OAuth认证来说说具体的功能实现,首先罗列一下关键字组,下面四组关键字跟我们接下来OAuth认证有非常大的关系。

第一组:(App Key和App Secret),这组参数就是本系列文本第一篇提到的建一个新的应用获取App Key和App Secret。

第二组:(Request Token和Request Secret)

第三组:(oauth_verifier

第四组:(user_id、Access Token和Access Secret)

新浪微博的OAuth认证过程,当用户第一次使用客户端软件时,客户端程序用第一组作为参数向新浪微博发起请求,然后新浪微博经过验证后返回第二组参数给客户端软件同时表示新浪微博信任本客户端软件,当客户端软件获取第二组参数时作为参数引导用户浏览器跳至新浪微博的授权页面,然后用户在新浪的这个授权页面里输入自己的微博账号和密码进行授权,完成授权后根据客户端设定的回调地址把第三组参数返回给客户端软件并表示用户也信任本客户端软件,接下客户端软件把第二组参数和第三组参数作为参数再次向新浪微博发起请求,然后新浪微博返回第四组参数给客户端软件,第四组参数需要好好的保存起来这个就是用来代替用户的新浪账号和密码用的,在后面调用api时都需要。从这个过程来看用户只是在新浪微博的认证网页输入过账户和密码并没有在客户端软件里输入过账户和密码,客户端软件只保存了第四组数据并没有保存用户的账户和密码,这样有效的避免了账户和密码透露给新浪微博之外的第三方应用程序,保证 了安全性。


新浪微博的SDK的导入: 新浪微博的SDK是源码方式开放的,和我们平时使用的有些不一样,导入步骤如下:

1)新浪微博官方的SDK包中一般有2个目录,一个是SDK的源码包(此包中有Android平台微博SDK说明文档),另一个是例子。首先需要将源码包导入到eclipse中。SDK工程的编码格式为UTF-8。

2)在需要集成新浪微博SDK包的工程项目中添加Library,右键 -> Properties -> Android。设置Library属性。

认证的代码如下,也可以直接参考例子中的AuthorizeActivity类的代码


private static final String CONSUMER_KEY = "*******";// 替换成你自己申请的KEY   
    private static final String CONSUMER_SECRET = "**************************"; // 替换陈你自己申请的SECRET  
    Weibo weibo = Weibo.getInstance();  
    weibo.setupConsumerConfig(CONSUMER_KEY, CONSUMER_SECRET);  
    // Oauth2.0 隐式授权认证方式  
    weibo.setRedirectUrl("http://www.sina.com");// 此处使用的URL必须和新浪微博上应用提供的回调地址一样  
    weibo.authorize(OAuthWeiboActivity.this, new AuthDialogListener());  
 

对于Mobile客户端应用来说,是不存在Server的,故此处的应用回调页地址只要与新浪微博开放平台->我的应用->应用信息->高级应用->授权设置->应用回调页中的url地址保持一致就可以了。

以下代码实现WeiboDialogListener接口,授权成功后可在onComplete函数中获得AccessToken信息。具体如何保存、使用AccessToken信息由开发者自行处理,比如存放在SharedPreferences中,但是AccessToken的有效期有限制,一般正常情况下是7天存活期,过期后需要重新获得。如果保存在SharedPreferences或者db文件中,则需要另外实现方法判断AccessToken是否过期(以最近保存过的时间为准),未过期则直接使用,过期后则按照正常流程重新获取.

class AuthDialogListener implements WeiboDialogListener   
    {  
            @Override  
            public void onComplete(Bundle values) {  
                String token = values.getString("access_token");  
                String expires_in = values.getString("expires_in");  
                Log.i(“info”,"access_token : " + token + "  expires_in: " + expires_in);  
                AccessToken accessToken = new AccessToken(token, CONSUMER_SECRET);  
                accessToken.setExpiresIn(expires_in);  
                Weibo.getInstance().setAccessToken(accessToken);  
                Intent intent = new Intent();  
                intent.setClass(OAuthWeiboActivity.this, MySinaWeiboActivity.class);  
                startActivity(intent);  
            }  
            @Override  
            public void onError(DialogError e) {  
                Toast.makeText(getApplicationContext(), "Auth error : " + e.getMessage(),  
                        Toast.LENGTH_LONG).show();  
            }  
            @Override  
            public void onCancel() {  
                Toast.makeText(getApplicationContext(), "Auth cancel", Toast.LENGTH_LONG).show();  
            }  
            @Override  
            public void onWeiboException(WeiboException e) {  
                Toast.makeText(getApplicationContext(), "Auth exception : " + e.getMessage(),  
                        Toast.LENGTH_LONG).show();  
            }  
        }  



分享到:
评论

相关推荐

    手把手教你开发新浪微博(完整版)

    一个完整的新浪微博客户端android版OAuth认证 开发我的新浪微博客户端-大图浏览以及保存篇 开发我的新浪微博客户端-阅读微博功能篇 开发我的新浪微博客户端-阅读微博UI篇 开发我的新浪微博客户端-用户首页面功能篇 ...

    新浪微博客户端源码

    新浪微博客户端!教你怎么完成新浪微博客户端的全过程!通过oauth2.0的认证登陆新浪微博!

    android开发新浪微博客户端+完整攻略

    这是用android开发的一个完整的新浪微博客户端,从Oauth认证开始,每一步都有详细的代码说明和讲解。是学习android开发的很好的例子。

    Android新浪微博客户端源代码

    Android手机上的新浪微博客户端程序Java源码下载,可了解到android中的域名获取等操作,http操作,发微博的作者操作,sqlite操作和微博浏览显示操作,包括了界面到数据库和网络较综合的操作技巧。包括使用sqlite创建...

    Android平台新浪微博开发实战视频教程(10集)

    教程名称:Android平台新浪微博开发实战视频教程(10集)教程目录:【】Android项目_-6(上)【】Android项目_新浪微博-4(上)【】Android项目_新浪微博Android客户端开发ppt【】Android项目_新浪微博OAuth认证-4(下)...

    新浪和腾讯微博Oauth认证Demo(php版)

    3./class/下,文件名中含有If的文件,定义的是接口.总计3个接口文件:各个网站的api访问路径(urlIf)、申请到的appkey接口(keyIf),返回的参数名接口(paramIf)。...本例中的OAuth客户端来源于新浪微博OAuth认证SDK。

    微博客户端含(新浪微博,腾讯微博)

    3.新浪微博SDK和腾讯微博SDK 4.HMAC加密算法 5.SQLite数据库相关操作 6.字符串处理,表情识别 7.JSON解析,XML解析:超链接解析,时间解析等 8.Android UI:样式文件,布局 9.异步加载图片,异步处理数据,多...

    weibo-android-example.rar_android_android 完整_weibo_新浪微博 android

    一个完整的新浪微博客户端android版OAuth认证示例,值得参考的

    Android应用源码YiBo聚合微博客户端

    本项目是一款专为Android用户打造的聚合型微博客户端,下面是官方对本项目功能的一些介绍: 一键同步所有帐号,支持新浪、腾讯、搜狐、网易和饭否微博平台; 即拍即传,方便的拍照功能,记录生活点滴,享受快乐微博;...

    Android 腾讯微博客户端源码.zip

    这个微博客户端中用到得一些知识点。...15:腾讯Oauth认证的使用(新浪的,人人的,淘宝的开放API也是基于这个的,版本不同可能) 16:ViewHolder以及LayoutInflater等的使用 17:腾讯API的调用与封装  

    Android应用源码YiBo聚合微博客户端.zip

    本项目是一款专为Android用户打造的聚合型微博客户端,下面是官方对本项目功能的一些介绍: 一键同步所有帐号,支持新浪、腾讯、搜狐、网易和饭否微博平台; 即拍即传,方便的拍照功能,记录生活点滴,享受快乐...

    新浪微博OAuth2认证android

    android客户端OAuth2认证实例

    【3K认证】新浪微博Java开发包 weibo4j 。好使

    weibo4j 或者叫 sinat4j 是新浪微博的 Java 客户端开发包,支持Basic Auth, OAuth, 上传图片,头像,地理位置等功能。 示例代码: package weibo4j.examples; import weibo4j.Status; import weibo4j.Weibo; ...

    新浪 腾讯微博分享

    在手机客户端 向新浪腾讯微博发送微博运用Oauth认证 第三方jar包

    MaoBo微博安卓客户端开源(原名YiBo).zip

    YiBo微博是一款专为Android用户打造的聚合型微博客户端,完美支持新浪、腾讯、搜狐、网易以及Twitter五大微博平台,界面清爽,使用简单,支持多账户跨平台同步发布与分享,为您带来不一样的使用体验。软件功能1. ...

    WeiBo:一个微博客户获得新浪微博

    新浪微博Android 客户端1、微博软件主要实现的功能 1.1、新浪微博 Oauth 认证 1.2、新浪微博 获取微博列表 1.3、新浪微博 发表微博 1.4、新浪微博 评论微博 1.5、新浪微博 转发微博 2、Oauth开放平台认证过程!...

    YiBo聚合微博源码.zip

    YiBo聚合微博源码是一款专为Android用户打造的聚合型微博客户端,下面是官方对本项目功能的一些介绍: 一键同步所有帐号,支持新浪、腾讯、搜狐、网易和饭否微博平台; 即拍即传,方便的拍照功能,记录生活点滴,...

    YiBo聚合微博

    YiBo聚合微博源码是一款专为Android用户打造的聚合型微博客户端,下面是官方对本项目功能的一些介绍:一键同步所有帐号,支持新浪、腾讯、搜狐、网易和饭否微博平台;即拍即传,方便的拍照功能,记录生活点滴,享受...

    android开发资料大全

    一个完整的新浪微博客户端android版OAuth认证示例 超爽的android抽屉效果 65个Android实例教程汇总 基本控件及基本动画效果dem 2011android面试题目及其答案大全.rar Android面试题集锦 (陆续更新)(最新2012-6-18...

Global site tag (gtag.js) - Google Analytics