Android实现新浪微博SSO授权登录分享文字图片等功能

新浪开发平台:http://open.weibo.com



新浪微博分享目前分为两种途径:

1,直接在自己的APP,弹出类似Dialog(sina集成)来完成授权,授权成功后可直接分享内容,全程都是在自己APP里完成分享。老版本的微博SDK中集成了弹出分享Dialog(WebView)的视图,以及插入文字、图片、URL等API,直接调用接口中的update就可以分享,此方法是在自己的APP中弹出类似Dialog的形式来完成的,分享的所有过程都在一个界面。

【APP分享-弹出sina封装好的Dialog-(授权)--分享---Dialog消失】

2,最新版的微博SDK,建议移动开发者使用SSO授权机制,这种机制牵引用户在分享时,跳转到手机中的新浪微博客户端,然后授权验证以及发送微博。
【APP携带要分享的数据-----跳转到微博客户端----(授权或登录)----分享-----返回APP】


如果使用老版本的SDK,代码量很少,就可以很简单的分享一条微博,但是授权验证时:Failed to receive access token,始终无法获得授权token,初步认为sina不再支持这种方式了。

如果使用新版本的SDK,带来的问题就是用户的手机一定要安装了 新浪微博客户端 否则无法分享。


本文是sina建议的SSO机制,APP间跳转和回调,跟着我的步骤走,让你很快实现分享功能。


成为开发者

打开新浪开发平台,都应该有新浪微博账号吧,登录好后,在网页右上角点击个人信息-编辑开发者信息:


首先你要成为一名开发者,类型的话我选择的是个人,公司性质还需要一系列审核,很麻烦,我只是为了在APP里实现分享功能,并不会延伸到支付等高级API,所以选择了个人开发者,完成后会给邮箱发邮件,一系列的动作,相信你没问题。(至于身份认证,需要上传开发者证件,我认为无所谓,目前只是分享功能)


创建应用

开发平台,点击管理中心,在这个界面我们需要创建一个应用,以供sina识别我们自己的APP。


sina说的很明确了,创建一个应用,得到appkey,就能测试了,至于之后的审核、上线,就看你的需求了,不需要审核,就可以实现分享的功能

创建应用

创建应用-移动APP应用地址什么之类的可以随意写(如果你只是demo)。

编辑应用

创建好后,记住APP_KEY,这是你身份标识,然后编辑应用:

你的APP是什么包名,这里就填什么,不一致的话,不能通过验证。

Android签名是sina让你使用它的APk,输入包名,生成一个唯一的MD5校验码


http://open.weibo.com/wiki/SDK 寻找Android SDK,下载下来,打开后有一个app_signatures.apk,部署到手机里,运行生成一个DM5签名,复制到网页中来。

Android下载地址就无所谓了,可以随意写。

高级信息

打开高级信息,编辑OAuth2.0 授权设置,因为是移动APP,我们要填写一个授权回调页,否则获取不到access_token,在这里我填写的是www.sina.com,【注意哦,这里填写什么,项目中的REDIRECT_URL的值就是什么,这俩得保持一直,否则验证不通过,就会遇到error:redicect_uri_mismatch 错误】,取消授权页这里可以什么都不输入,目前用不到。


关联账号

打开测试账号,输入自己的微博名称,关联一下,到此为止,已经成功了一半。



开发测试

导入jar包

把下载好的weibo_sdk.jar导入到项目中的libs。

 配置跳转Action

在AndroidManifest.xml中,在需要接受消息(微博APP分享成功返回到自己APP)的类里声明对应的Action:

com.sina.weibo.sdk.action.ACTION_SDK_REQ_ACTIVITY如下代码:

[java]  view plain copy
  1. <activity  
  2.        android:name=".DemoActivity"  
  3.        android:configChanges="keyboardHidden|orientation"  
  4.        android:launchMode="singleTask"  
  5.        android:screenOrientation="portrait"  
  6.        android:theme="@android:style/Theme.Black.NoTitleBar" >  
  7.          
  8.        <intent-filter>  
  9.            <action android:name="com.sina.weibo.sdk.action.ACTION_SDK_REQ_ACTIVITY"/>  
  10.            <category android:name="android.intent.category.DEFAULT"/>  
  11.              
  12.        </intent-filter>  
  13.          
  14.          
  15.    </activity>  
对应的Activity要实现IWeiboHandler.Response接口


初始化

[java]  view plain copy
  1. protected Weibo mWeibo;  
  2. public static final String WEIBO_KEY = "你的APP_KEY";  
  3. public static final String REDIRECT_URL = "http://www.sina.com";//<span style="font-family:Arial,Helvetica,sans-serif">【和网站自己设置的回调页保持一致】</span>  
  4.   
  5. public Oauth2AccessToken mAccessToken;  
  6. public IWeiboAPI weiboApi;  
  7. protected Bitmap mSharedPic;  
  8. protected SsoHandler mSsoHandler;  
  9.   
  10. @Override  
  11. protected void onCreate(Bundle savedInstanceState) {  
  12.     super.onCreate(savedInstanceState);  
  13.     // TODO init  
  14.     mWeibo = Weibo.getInstance(WEIBO_KEY, REDIRECT_URL, null);  
  15.     weiboApi = WeiboSDK.createWeiboAPI(AppMain.this, WEIBO_KEY);  
  16.     weiboApi.responseListener(getIntent(), this);  
[java]  view plain copy
  1. <span style="white-space:pre">      </span>String path = Environment.getExternalStorageDirectory().toString()  
  2. <span style="white-space:pre">              </span>+ "/test.png";  
  3. <span style="white-space:pre">      </span>mSharedPic = BitmapFactory.decodeFile(path);  
  4.           
  5.     }  

Callback

在onCreate()和onNewIntent里加入weiboApi.responseListener(intent,this);

[java]  view plain copy
  1. @Override  
  2. protected void onNewIntent(Intent intent) {  
  3.     super.onNewIntent(intent);  
  4.     weiboApi.responseListener(intent, this);  
  5. }  

当从微博发博器界面返回到该 Activity时 , 接 口 函 数 IWeiboHandler.Response.onResponse(...)会被调用,用户可以从该函数内获取成功或失败,以及取消的信息,如下:

[java]  view plain copy
  1. /** 
  2.  * 当从微博返回到该Activity时,此接口函数会被调用 
  3.  */  
  4. @Override  
  5. public void onResponse(BaseResponse baseResp) {  
  6.     switch (baseResp.errCode) {  
  7.     case com.sina.weibo.sdk.constant.Constants.ErrorCode.ERR_OK:  
  8.         Toast.makeText(this"分享成功", Toast.LENGTH_LONG).show();  
  9.         break;  
  10.     case com.sina.weibo.sdk.constant.Constants.ErrorCode.ERR_FAIL:  
  11.         Toast.makeText(this, baseResp.errMsg + "分享失败!", Toast.LENGTH_LONG)  
  12.                 .show();  
  13.         break;  
  14.     case com.sina.weibo.sdk.constant.Constants.ErrorCode.ERR_CANCEL:  
  15.         Toast.makeText(this"取消分享", Toast.LENGTH_LONG).show();  
  16.         break;  
  17.     }  
  18. }  

在onActivityResult里加入回调函数

当用户点击分享按钮时,会进行SSO  登录,登陆完成后,返回该Activity,此时,我们需要在 onActivityResult(…)中调用 mSsoHandler.authorizeCallBack(requestCode, 
resultCode,  data) 函数,整个登陆才能结束。授权成功后,SDK会默认通过 AccessTokenKeeper 将access_token、expires_in信息其保存到SharedPreference 里面, 
用 户 也 可 在 onComplete函 数中通过

 Oauth2AccessToken        token  =   AccessTokenKeeper.readAccessToken(getApplicationContext()); 获得 access_token 、 expires_in 信息。 

[java]  view plain copy
  1. @Override  
  2. protected void onActivityResult(int requestCode, int resultCode, Intent data) {  
  3.     super.onActivityResult(requestCode, resultCode, data);  
  4.     if (mSsoHandler != null) {  
  5.         mSsoHandler.authorizeCallBack(requestCode, resultCode, data);  
  6.     }  
  7. }  

实现WeiboAuthListener 接口 

授权成功后,SDK 会默认通过AccessTokenKeeper 将access_token、expires_in 信息其保存到SharedPreference 里面,第三方也可在onComplete 函数中获得access_token、expires_in信息。具体如何保存和使用access_token 信息由开发者自行处理。 

[java]  view plain copy
  1. /*** 
  2.  * 实现WeiboAuthListener接口,返回授权结果 
  3.  * 通过access_token和expires_in获取accesstoken 
  4.  * @author Administrator 
  5.  * 
  6.  */  
  7. class AuthDialogListener implements WeiboAuthListener {  
  8.   
  9.     @Override  
  10.     public void onCancel() {  
  11.         Toast.makeText(this"Auth onCancel", Toast.LENGTH_LONG).show();  
  12.     }  
  13.       
  14.     @Override  
  15.     public void onComplete(Bundle values) {  
  16.         String token = values.getString("access_token");  
  17.         String expires_in = values.getString("expires_in");  
  18.         mAccessToken = new Oauth2AccessToken(token, expires_in);  
  19.         if (mAccessToken.isSessionValid()) {  
  20.             AccessTokenKeeper.keepAccessToken(this, mAccessToken);  
  21.             Toast.makeText(this"授权认证成功!", Toast.LENGTH_LONG).show();  
  22.             // TODO  
  23.             reqMsg(mSharedPic);  
  24.         }  
  25.     }  
  26.   
  27.     @Override  
  28.     public void onError(WeiboDialogError arg0) {  
  29.         Toast.makeText(this"授权失败:" + arg0.getMessage(), Toast.LENGTH_LONG)  
  30.                 .show();  
  31.     }  
  32.   
  33.     @Override  
  34.     public void onWeiboException(WeiboException arg0) {  
  35.         Toast.makeText(this"Auth Exception:" + arg0.getMessage(),  
  36.                 Toast.LENGTH_LONG).show();  
  37.     }  
  38.   
  39. }  

调用authorize 方法,认证并授权 

调用Weibo.authorize(…)方法,弹出授权对话框,进行授权。授权成功后即可获得 access_token。 

在分享的按钮事件里添加验证:

[java]  view plain copy
  1. @Override  
  2. public void onClick(View v) {  
  3.     mAccessToken = AccessTokenKeeper.readAccessToken(AppMain.this);  
  4.   
  5.     if (mAccessToken.isSessionValid()) {  
  6.         // TODO发微博  
  7.         reqMsg(mSharedPic);  
  8.     } else {  
  9.         /** 不使用SSO方式进行授权验证 */  
  10.         // mWeibo.anthorize(AppMain.this, new AuthDialogListener());  
  11.   
  12.         /** 使用SSO方式进行授权验证 */  
  13.         mSsoHandler = new SsoHandler(this, mWeibo);  
  14.         mSsoHandler.authorize(new AuthDialogListener(), null);  
  15.     }  
  16.   
  17. }  

分享微博

[java]  view plain copy
  1. /** 
  2.  * 向weibo 客户端注册发送一个携带:文字、图片等数据 
  3.  *  
  4.  * @param bitmap 
  5.  */  
  6. public void reqMsg(Bitmap bitmap) {  
  7.   
  8.     weiboApi.registerApp();  
  9.   
  10.     /*图片对象*/  
  11.     ImageObject imageobj = new ImageObject();  
  12.   
  13.     if (bitmap != null) {  
  14.         imageobj.setImageObject(bitmap);  
  15.     }  
  16.   
  17.     /*微博数据的message对象*/  
  18.     WeiboMultiMessage multmess = new WeiboMultiMessage();  
  19.     TextObject textobj = new TextObject();  
  20.     textobj.text = "这是我的测试微博分享消息,大家看的到吗?";  
  21.   
  22.     multmess.textObject = textobj;  
  23.     multmess.imageObject = imageobj;  
  24.     /*微博发送的Request请求*/  
  25.     SendMultiMessageToWeiboRequest multRequest = new SendMultiMessageToWeiboRequest();  
  26.     multRequest.multiMessage = multmess;  
  27.     //以当前时间戳为唯一识别符  
  28.     multRequest.transaction = String.valueOf(System.currentTimeMillis());  
  29.     weiboApi.sendRequest(this, multRequest);  
  30. }  


运行效果图:

授权


SSO模式的授权


登录


分享


分享成功返回自己APP


网页微博效果



weiboSDK老版本和新版本区别:


答案是,新版本已经把类似StatusesAPI这种封装给取消了,也就是说,如果想不跳转微博客户端来分享,在自己APP里直接分享,就需要自己写StatusesAPI,调用微博api接口,实现分享。


到此为止,微博分享就成功啦,遇到errorcode千万不要着急头大,静下心来去openweibo看错误码标识,弄懂流程很容易就可以通过授权了,分享是最基本功能,以后还有很多接口可以调用,大家有什么问题或心得就在这里交流就可以哦~~


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

开发平台问答系统:http://open.weibo.com/qa/index.php?qa=20521&qa_1=%E4%BD%BF%E7%94%A8%E6%96%B0%E7%89%88sdk%E4%B8%8D%E6%83%B3%E8%B7%B3%E8%BD%AC%E5%BE%AE%E5%8D%9A%E5%AE%A2%E6%88%B7%E7%AB%AF%E8%83%BD%E5%90%A6%E7%9B%B4%E6%8E%A5%E5%8F%91%E9%80%81%E5%BE%AE%E5%8D%9A%E5%88%86%E4%BA%AB%EF%BC%9F

仿Oauth实现微博发文字图片:http://www.cnblogs.com/snake-hand/archive/2012/04/06/2454362.html

OAuth2.0授权机制:http://open.weibo.com/wiki/%E6%8E%88%E6%9D%83%E6%9C%BA%E5%88%B6%E8%AF%B4%E6%98%8E#.E7.A7.BB.E5.8A.A8.E5.BA.94.E7.94.A8.E7.9A.84.E9.AA.8C.E8.AF.81.E6.8E.88.E6.9D.83

Android SDK:https://github.com/mobileresearch/weibo_android_sdk

Scope接口:http://open.weibo.com/wiki/Scope

API文档:http://open.weibo.com/wiki/API%E6%96%87%E6%A1%A3

微博API:http://open.weibo.com/wiki/%E5%BE%AE%E5%8D%9AAPI

Error codehttp://open.weibo.com/wiki/Error_code

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值