zoukankan      html  css  js  c++  java
  • 安卓仿制新浪微博(一)之OAuth2授权接口

    这里需要用到请求授权(authorize)以及获取授权(access_token)

    第一步:

    将新浪的sdk放在src/libs下面

    二:

    //创建方法实现authorize
    public void getauthorize(){
    //获取实例
    //实例化的方法一般有三种
    //1.最常见的通过new;2.通过getinstence;3.通过工厂(Facetory)
    Weibo weibo=Weibo.getInstence();//里面有三个参数.String appKey, String redirectUrl, String aScope,
    //分别是你应用的appKey,网址,想要获取的权限可以把这些属性写在一个类里面设置成静态
    //这里需要两个参数,一个为context,一个listenr
    //context很好解决放的就是this,而listener需要的是WeiboAuthListener类型,我们没有所有就直接new一个
    weibo.aututhorize(this,new WeiboAuthListener(){
    //WeiboAuthListener里面自动生成4个方法
    //抛出异常时
                @Override
                public void onWeiboException(WeiboException arg0) {
                    Log.d(TAG, "onWeiboException" + arg0);
    
                }
    
                // 出错时
                @Override
                public void onError(WeiboDialogError arg0) {
                    Log.d(TAG, "onError" + arg0);
    
                }
    
                // 成功时
                @Override
                public void onComplete(Bundle arg0) {//这里的Bundle arg0就是返回的code数据
                    Log.d(TAG, "onComplete" + arg0);
                    String code = arg0.getString("code");
                    //这是获得Toak的方法,在下面会写到
                    getToken(code);
                }
    
                // 取消时
                @Override
                public void onCancel() {
                    Log.d(TAG, "onCancel=====");
    
                }
    
    });
    }

    现在已经获得code,现在我们需要通过code得到Token

    //实现access_token获取已经授权的Access_token
    
    public void getToken(){
    //现在来填充参数
    String url="https://api.weibo.com/oauth2/access_token";//注意这里不能有空格
    WeiboParameters params=new WeiboParameters();
    //params的中文就是参数的意思,所有将参数放在里面,所需的请求参数新浪API里面都有http://open.weibo.com/wiki/OAuth2/access_token
    params.add("client_id", staticname.AppKey);//第一个是key,第二个是value
    params.add("client_secret", staticname.App_Secret);
    params.add("grant_type", "authorization_code");
    params.add("code", code);
    params.add("redirect_uri", staticname.RedirectUrl);
    
    //第一步先写下面这个
    AsyncWeiboRunner.request(url,params,"POST",new RequestListener(){
    //自动生成四个方法
    @Override
                public void onIOException(IOException arg0) {
                    Log.d(TAG, "onIOException------" + arg0);
    
                }
    
                @Override
                public void onError(WeiboException arg0) {
                    Log.d(TAG, "onError------" + arg0);
    
                }
    
                @Override
                public void onComplete4binary(ByteArrayOutputStream arg0) {
                    Log.d(TAG, "onComplete4binary------" + arg0);
    
                }
    
                @Override
                public void onComplete(String js) {// 得到Toak的就是js
                    Log.d(TAG, "onComplete------" + js);
                    //这里json解析的作用下面会讲到
                    Json json = new Json();
                    try {
                        json.pramas(js, Welcom.this);
                        handler.sendEmptyMessage(CODE_VIEWPAGER);
                    } catch (JSONException e) {
                        // TODO Auto-generated catch block
                        e.printStackTrace();
                    }
                }
    
    
    
    )};//这里需要四个参数分别是String url, WeiboParameters params, String httpMethod, RequestListener listener
                                //第一个参数代表是新浪API里的所给网站,第二,四个参数没有和上面的方法一样new出来,第三个参数新浪API同样给出了是POST
    
    }
    View Code

    现在已经获得Token了,那我们要实现如果用户已经授权过了之后,在token的有效期之前都不用重新授权的效果

    这就需要将获得的Token解析并且使用SharedPreferences来存储

     1 //新建一个类
     2 //Token的返回数据请查看新浪微博API
     3 public class Json{
     4 //需要获取数据源,所以在方法上加了一个String js,至于为什么还要加一个context在Sharde会讲到
     5 public void json(String js,Context context){
     6 JsonObject json=new JsonObject(js);
     7 //这里我们只需三个数据
     8 String access_token = jsonObject.getString("access_token");
     9 long expires_in = jsonObject.getLong("expires_in");//有效期
    10 String uid = jsonObject.getString("uid");//用户id
    11 Sharder sharder = new Sharder();
    12 //将解析得到的数据存入SharedPreferences
    13 sharder.putToke(context, access_token, expires_in);
    14 sharder.putuid(context, uid);
    15 }
    16 
    17 }
    Json.class
     1 //新建一个类来存储数据
     2 public class Sharde(){
     3 
     4 public void putToken(Context context,String token,long expires_in){
     5 //要使用context调用get来获取SharedPreferences,而json里要使用此方法,所以json里面也要有context
     6 SharedPreferences preferences=context.getSharedPreferences("token",SharedPreferences.Moden_PRI);//第一个是SharedPreferences的名字,第二个是数据存储形式
     7 Editor editor= preferences.edit();
     8 editor.putString("token",token);//因为这要放token的值所以要在方法里写上
     9 editor.putLong("expires_in",expires_in);
    10 //这个不要忘了
    11 editor.commt;
    12 }
    13 public void putuid(Context context,String uid){
    14 SharedPreferences preferences=context.getSharedPreferences("uid",SharedPreferences.Moden_PRI);
    15 Editor editor= preferences.edit();
    16 editor.putString("token",token);
    17 //这个不要忘了
    18 editor.commt;
    19 }
    20 //将SharedPreferences,的数据拿出来,以供判断使用
    21 public Oauth2AccessToken getToken(){
    22 SharedPreferences preferences=context.getSharedPreferences("token",SharedPreferences.Moden_PRI);
    23 String token = preferences.getString("token", null);//第二个参数是默认值的意思
    24 long expires_in = preferences.getLong("expires_in", 0);
    25 return  new    Oauth2AccessToken(token,expires_in+"") ;//返回Token,里面不能放long型所以要转成String型
    26 }
    27 
    28 public String getuid(){
    29 SharedPreferences preferences = context.getSharedPreferences("uid",
    30                 context.MODE_PRIVATE);
    31         String uid = preferences.getString("uid", null);
    32         return uid;
    33 }
    34 
    35 
    36 }
    Sharde.class

    现在我们要在主Activty里面判断

     1 public void onClick(View v) {
     2     if (sharder.getToke(Welcom.this).isSessionValid()) {
     3         Intent intent=new Intent(Welcom.this,Viewpager.class);
     4         startActivity(intent);//这是实现跳转的,下篇文章再说
     5         return;
     6     }
     7     getcode();
     8 
     9 }
    10 });

    最后不要忘记注册Activty和权限

     <uses-permission android:name="android.permission.INTERNET" />
        <uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />

     这并不是一篇教程,仅仅是我给老师教的作业,代码也不是在eclipse里面打的,里面可能有很多错误,希望大家多多见谅,源代码明天再上传,今天太累了

  • 相关阅读:
    BZOJ 3754 Tree之最小方差树
    【CSS】318- CSS实现宽高等比自适应容器
    【Vuejs】317- 提升90%加载速度——Vuecli下的首屏性能优化
    【H5】316- 移动端H5跳坑指南
    【每周小回顾】2- 一起回顾上周精彩内容
    【Webpack】315- 手把手教你搭建基于 webpack4 的 vue2 多页应用
    【Web技术】314- 前端组件设计原则
    【JS】313- 复习 回流和重绘
    【JS】312- 复习 JavaScript 严格模式(Strict Mode)
    【Canvas】311- 解决 canvas 在高清屏中绘制模糊的问题
  • 原文地址:https://www.cnblogs.com/foreverstudent/p/3271739.html
Copyright © 2011-2022 走看看