Android 微博登录

最近公司有要求接入微博的登录,这里记录下最新的接入方法, 

一 、首先你要自己去微博平台申请好  appkey 、

二、Androidstudio 集成

1.在Project的build.gradle文件中添加依赖配置:

allprojects {
 repositories {
 maven { url 'https://dl.bintray.com/thelasterstar/maven/' }
 }
 }

2.在Module的build.gradle文件中添加依赖和属性配置

 android {
 defaultConfig {
 ndk {
// ᦡᗝඪ೮ጱSOପຝ຅
 abiFilters 'armeabi' //, 'armeabi-v7a','arm64-v8a'
 }
 }
 }
 dependencies {
 compile 'com.sina.weibo.sdk:core:9.12.0:openDefaultRelease@aar'
 }

3.在AndroidManifest.xml中添加权限

 
  
    

4.在Proguard混淆文件中增加以下配置:

-keep public class com.sina.weibo.sdk.**{*;}

 

三、使用SDK

 //微博
    public static String WeiB_appkey = "您自己的appkey";
  
    /**
     * 当前 DEMO 应用的回调页,第三方应用可以使用自己的回调页。
     * 建议使用默认回调页:https://api.weibo.com/oauth2/default.html
     */
    public static final String REDIRECT_URL = "http://www.sina.com";
    /**
     * WeiboSDKDemo 应用对应的权限,第三方开发者一般不需要这么多,可直接设置成空即可。
     * 详情请查看 Demo 中对应的注释。
     */
    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," + "invitation_write";






 /**
     * 微博登录
     */
    private void WeiBLogin() {
        AuthInfo authInfo = new AuthInfo(this, WeiB_appkey, REDIRECT_URL, SCOPE);
        mWBAPI = WBAPIFactory.createWBAPI(this);
        mWBAPI.registerApp(this, authInfo);
        mWBAPI.authorizeClient(new WbAuthListener() {
            @Override
            public void onComplete(Oauth2AccessToken token) {

                //调用微博的用户请求地址,获取用户信息,新版的微博,用户信息将不再直接返回,必须调用以下的接口才能返回用户的详细信息 https://api.weibo.com/2/users/show.json
                Map map = new HashMap<>();
                map.put("access_token", token.getAccessToken());
                map.put("uid", token.getUid());
                Set> entries = map.entrySet();
                StringBuffer absUrl = new StringBuffer();
                int size = 0;
                for (Map.Entry item : entries) {
                    if (size == 0) {
                        absUrl.append("https://api.weibo.com/2/users/show.json").append("?").append(item.getKey()).append("=").append(item.getValue());
                        size++;
                    } else {
                        absUrl.append("&").append(item.getKey()).append("=").append(item.getValue());
                    }
                }

                OkHttpClient client = new OkHttpClient();
                Request request = new Request.Builder()
                        .url(absUrl.toString())
                        .build();
                client.newCall(request).enqueue(new okhttp3.Callback() {
                    @Override
                    public void onFailure(Call call, IOException e) {

                    }

                    @Override
                    public void onResponse(Call call, Response response) throws IOException {
                        if (response.isSuccessful()) {
                            String result = response.body().string();
                            if (result == null) {
                                return;
                            }
                            WeiBEntity weib = new Gson().fromJson(result, WeiBEntity.class);
                            if (weib == null) {
                                return;
                            }
                            userInfoT = new UserInfoT();
                            if (weib.getScreen_name() != null && !weib.getScreen_name().isEmpty()) {
                                userInfoT.setNickname(userInfoT.getNickname());
                            }
                            if (weib.getAvatar_hd() != null && !weib.getAvatar_hd().isEmpty()) {
                                userInfoT.setHeadurl(weib.getAvatar_hd());
                            }
                            if (weib.getGender() != null && !weib.getGender().isEmpty()) {
                                //性别,m:男、f:女、n:未知
                                if (weib.getGender().equals("m")) {
                                    userInfoT.setGender(1);
                                } else if (weib.getGender().equals("f")) {
                                    userInfoT.setGender(2);
                                } else if (weib.getGender().equals("n")) {
                                    userInfoT.setGender(1);
                                }
                            }
                            if (weib.getDescription() != null && !weib.getDescription().isEmpty()) {
                                userInfoT.setDistrict(weib.getDescription());
                            }


                            // todo  上传数据  这里是将第三方的平台的用户信息传递给后台,
                          


                                }

                                @Override
                                protected void onError(Call call, int statusCode, String errMessage) {
                                    errMessage.toString();

                                }
                            });


                        }


                    }
                });


            }

            @Override
            public void onError(UiError error) {
                Toast.makeText(LoginActivity.this, "微博授权出错", Toast.LENGTH_SHORT).show();
            }

            @Override
            public void onCancel() {
                Toast.makeText(LoginActivity.this, "微博授权取消", Toast.LENGTH_SHORT).show();
            }
        });

    }

微博用户接口返回json 示例

{
    "id": 1404376560,
    "screen_name": "zaku",
    "name": "zaku",
    "province": "11",
    "city": "5",
    "location": "北京 朝阳区",
    "description": "人生五十年,乃如梦如幻;有生斯有死,壮士复何憾。",
    "url": "http://blog.sina.com.cn/zaku",
    "profile_image_url": "http://tp1.sinaimg.cn/1404376560/50/0/1",
    "domain": "zaku",
    "gender": "m",
    "followers_count": 1204,
    "friends_count": 447,
    "statuses_count": 2908,
    "favourites_count": 0,
    "created_at": "Fri Aug 28 00:00:00 +0800 2009",
    "following": false,
    "allow_all_act_msg": false,
    "geo_enabled": true,
    "verified": false,
    "status": {
        "created_at": "Tue May 24 18:04:53 +0800 2011",
        "id": 11142488790,
        "text": "我的相机到了。",
        "source": "新浪微博",
        "favorited": false,
        "truncated": false,
        "in_reply_to_status_id": "",
        "in_reply_to_user_id": "",
        "in_reply_to_screen_name": "",
        "geo": null,
        "mid": "5610221544300749636",
        "annotations": [],
        "reposts_count": 5,
        "comments_count": 8
    },
    "allow_all_comment": true,
    "avatar_large": "http://tp1.sinaimg.cn/1404376560/180/0/1",
    "verified_reason": "",
    "follow_me": false,
    "online_status": 0,
    "bi_followers_count": 215
}

返回字段说明


返回值字段	字段类型	字段说明
id	                  int64	用户UID
idstr	              string	字符串型的用户UID
screen_name	          string	用户昵称
name	              string	友好显示名称
province	          int	用户所在省级ID
city	              int	用户所在城市ID
location	          string	用户所在地
description	          string	用户个人描述
url	                  string	用户博客地址
profile_image_url	  string	用户头像地址(中图),50×50像素
profile_url	          string	用户的微博统一URL地址
domain	              string	用户的个性化域名
weihao	              string	用户的微号
gender	              string	性别,m:男、f:女、n:未知
followers_count	      int	粉丝数
friends_count	      int	关注数
statuses_count	      int	微博数
favourites_count	  int	收藏数
created_at	          string	用户创建(注册)时间
following	          boolean	暂未支持
allow_all_act_msg	  boolean	是否允许所有人给我发私信,true:是,false:否
geo_enabled	          boolean	是否允许标识用户的地理位置,true:是,false:否
verified	          boolean	是否是微博认证用户,即加V用户,true:是,false:否
verified_type	      int	暂未支持
remark	              string	用户备注信息,只有在查询用户关系时才返回此字段
status	object	用户的最近一条微博信息字段 详细
allow_all_comment	boolean	是否允许所有人对我的微博进行评论,true:是,false:否
avatar_large	string	用户头像地址(大图),180×180像素
avatar_hd	string	用户头像地址(高清),高清头像原图
verified_reason	string	认证原因
follow_me	boolean	该用户是否关注当前登录用户,true:是,false:否
online_status	int	用户的在线状态,0:不在线、1:在线
bi_followers_count	int	用户的互粉数
lang	string	用户当前的语言版本,zh-cn:简体中文,zh-tw:繁体中文,en:英语

 

注意:1.如果您的App需要上传到 Google play store  , 您需要将READ_PHONE_STATE权限屏蔽掉或者移除,否则可能会被下架

           2. REDIRECT_RUL 的地址  必须跟平台上填写的一致哦,否则会提示      error :redirect_uri_mismatch   

 

更多问题请在这里查阅哦:https://open.weibo.com/wiki/%E5%B8%B8%E8%A7%81%E9%97%AE%E9%A2%98

 

 

 

 

你可能感兴趣的:(Android,Android,微博登录,Android,开发)