首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 移动开发 > 移动开发 >

新浪微博客户端 - OAuth认证

2012-08-07 
新浪微博客户端 -- OAuth认证 OAuth的基本概念,OAUTH协议为用户资源的授权提供了一个安全的、开放而又简易

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

新浪微博客户端 - 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类的代码


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();              }          }  



热点排行