Android教程網
  1. 首頁
  2. Android 技術
  3. Android 手機
  4. Android 系統教程
  5. Android 游戲
 Android教程網 >> Android技術 >> Android開發實例 >> Android集成新浪微博第三方登錄的方法

Android集成新浪微博第三方登錄的方法

編輯:Android開發實例

本文實例講述了Android集成新浪微博第三方登錄的方法。分享給大家供大家參考。具體實現方法如下:

1.下載微博的sdk ,導入微博的jar包兩個 android-support-v4.jar和weibosdkcore.jar兩個包

2.把新浪微博中的demo_src中SDK中的com,導入到項目中

3.用demo中的constants,主要是參數設置,將裡面的參數改成自己的參數。

4.編寫代碼,主要步驟如下:
代碼如下:
// 初始化微博對象
mWeiboAuth = new WeiboAuth(this, Constants.APP_KEY, Constants.REDIRECT_URL, Constants.SCOPE);
// sinaAuthorWebView.loadUrl("https://open.weibo.cn/oauth2/authorize?scope=email&redirect_uri=http://www.sina.com&state=flashmemoAndroid&forcelogin=true&display=mobile&client_id=2529326755");
//獲取code
mWeiboAuth.authorize(new AuthListener(), WeiboAuth.OBTAIN_AUTH_CODE);
// 第二步:通過 Code 獲取 Token
fetchTokenAsync(mCode, WEIBO_DEMO_APP_SECRET);

5.主要的核心代碼如下:
代碼如下:
/**
* 微博認證授權回調類。
*/
class AuthListener implements WeiboAuthListener {

@Override
public void onComplete(Bundle values) {
if (null == values) {
// 獲取code失敗
return;
}
String code = values.getString("code");
if (TextUtils.isEmpty(code)) {
// 獲取code失敗 
return;
}
// 獲取code成功
mCode = code;
// 獲取code成功,第二步:通過 Code 獲取 Token
fetchTokenAsync(mCode, WEIBO_DEMO_APP_SECRET);
}

@Override
public void onCancel() {
Log.e("LoginActivity", "sinaAuth cancel");
//如果取消授權,那麼可以調到登錄頁面等
}

@Override
public void onWeiboException(WeiboException e) {
Log.e("LoginActivity", "sinaAuth exception :" + e.getMessage());
}
}

/**
* 該 Handler 配合 {@link RequestListener} 對應的回調來更新 UI。
*/
private Handler mHandler = new Handler() {
public void handleMessage(Message msg) {

switch (msg.what) {
case MSG_FETCH_TOKEN_SUCCESS:
// 顯示 Token
// String date = new
// SimpleDateFormat("yyyy/MM/dd HH:mm:ss").format(
// new java.util.Date(mAccessToken.getExpiresTime()));
// String format =
// getString(R.string.weibosdk_demo_token_to_string_format_1);

// 獲取tocken成功
break;

case MSG_FETCH_TOKEN_FAILED:
// Toast.makeText(WBAuthCodeActivity.this,
// R.string.weibosdk_demo_toast_obtain_token_failed,
// Toast.LENGTH_SHORT).show();
// 獲取tocken失敗
break;
default:
break;
}
};
};

/**
* 異步獲取 Token。
*
* @param authCode
*            授權 Code,該 Code 是一次性的,只能被獲取一次 Token
* @param appSecret
*            應用程序的 APP_SECRET,請務必妥善保管好自己的 APP_SECRET,
*            不要直接暴露在程序中,此處僅作為一個DEMO來演示。
*/
public void fetchTokenAsync(String authCode, String appSecret) {
/*
* LinkedHashMap<String, String> requestParams = new
* LinkedHashMap<String, String>();
* requestParams.put(WBConstants.AUTH_PARAMS_CLIENT_ID,
* Constants.APP_KEY);
* requestParams.put(WBConstants.AUTH_PARAMS_CLIENT_SECRET,
* appSecretConstantS.APP_SECRET);
* requestParams.put(WBConstants.AUTH_PARAMS_GRANT_TYPE,
* "authorization_code");
* requestParams.put(WBConstants.AUTH_PARAMS_CODE, authCode);
* requestParams.put(WBConstants.AUTH_PARAMS_REDIRECT_URL,
* Constants.REDIRECT_URL);
*/
WeiboParameters requestParams = new WeiboParameters();
requestParams.add(WBConstants.AUTH_PARAMS_CLIENT_ID, Constants.APP_KEY);
requestParams.add(WBConstants.AUTH_PARAMS_CLIENT_SECRET, appSecret);
requestParams.add(WBConstants.AUTH_PARAMS_GRANT_TYPE,
"authorization_code");
requestParams.add(WBConstants.AUTH_PARAMS_CODE, authCode);
requestParams.add(WBConstants.AUTH_PARAMS_REDIRECT_URL,
Constants.REDIRECT_URL);

/**
* 請注意: {@link RequestListener} 對應的回調是運行在後台線程中的, 因此,需要使用 Handler 來配合更新
* UI。
*/
AsyncWeiboRunner.request(OAUTH2_ACCESS_TOKEN_URL, requestParams,
"POST", new RequestListener() {
@Override
public void onComplete(String response) {
LogUtil.d(TAG, "get token Response: " + response);

Oauth2AccessToken token = Oauth2AccessToken
.parseAccessToken(response);
if (token != null && token.isSessionValid()) {

LogUtil.d(TAG, "Success! " + token.toString());

mAccessToken = token;
// 獲取token成功,可以做出相應的處理

// 通知UI改變
mHandler.obtainMessage(MSG_FETCH_TOKEN_SUCCESS)
.sendToTarget();

@Override
public void onComplete4binary(
ByteArrayOutputStream responseOS) {
LogUtil.e(TAG, "onComplete4binary...");
mHandler.obtainMessage(MSG_FETCH_TOKEN_FAILED)
.sendToTarget();
}

@Override
public void onIOException(IOException e) {
LogUtil.e(TAG, "onIOException: " + e.getMessage());
mHandler.obtainMessage(MSG_FETCH_TOKEN_FAILED)
.sendToTarget();
}

@Override
public void onError(WeiboException e) {
LogUtil.e(TAG, "WeiboException: " + e.getMessage());
mHandler.obtainMessage(MSG_FETCH_TOKEN_FAILED)
.sendToTarget();
}
});
}
主要是改寫complete相應的方法即可。handler主要是通知界面做出改變
UI Handler的參數調用問題的參數
代碼如下:
/** 獲取 Token 成功或失敗的消息 */
private static final int MSG_FETCH_TOKEN_SUCCESS = 1;
private static final int MSG_FETCH_TOKEN_FAILED = 2;

希望本文所述對大家的Android程序設計有所幫助。

  1. 上一頁:
  2. 下一頁:
熱門文章
閱讀排行版
Copyright © Android教程網 All Rights Reserved