Android仿新浪微博oauth2.0授權(quán)界面實現(xiàn)代碼(2)
oauth2.0授權(quán)界面,大致流程圖:

前提準備:
在新浪開放平臺申請appkey和appsecret:http://open.weibo.com/.
熟悉oauth2.0協(xié)議,相關(guān)知識:http://www.ruanyifeng.com/blog/2014/05/oauth_2_0.html
OAuth2的access_token接口:http://open.weibo.com/wiki/OAuth2/access_token
代碼詳解
大致思路如下:建立一個webview加載授權(quán)界面,授權(quán)回調(diào)地址請參考Constants.java里面有詳細注解。頁面加載時會回調(diào)該方法,如果用戶同意(輸入自己微博的賬號密碼)就會成功獲取code然后發(fā)送一個異步的post請求獲access_token 若成功獲取access_token信息,則使用SharedPreferences保存所有重要信息,并跳轉(zhuǎn)到主界面。
異步的post設(shè)置的請求參數(shù)必須跟OAuth2的access_token接口里要求的請求參數(shù)一一對應(yīng)。
這里獲取的access_token是后來每個接口的必備請求參數(shù)。
**
* 自定義授權(quán)界面,申請令牌
*/
public class OAuthActivity extends Activity {
//保存數(shù)據(jù)信息
private SharedPreferences preferences;
private static final String TAG = "OAuthActivity";
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.webview);
//獲取只能被本程序讀寫的SharedPreferences對象
preferences = getSharedPreferences("OAuth2.0", Context.MODE_PRIVATE);
//WebView加載回調(diào)頁
WebView webView = (WebView) findViewById(R.id.webView);
//管理WebView
WebSettings webSettings = webView.getSettings();
//啟用JavaScript調(diào)用功能
webSettings.setJavaScriptEnabled(true);
//啟用縮放網(wǎng)頁功能
webSettings.setSupportZoom(true);
//獲取焦點
webView.requestFocus();
//判斷網(wǎng)絡(luò)連接狀態(tài),無網(wǎng)絡(luò)則去設(shè)置網(wǎng)絡(luò),有網(wǎng)則繼續(xù)
String url = Constants.URL;
webView.loadUrl(url);
//WebViewClient主要幫助WebView處理各種通知、請求事件
WebViewClient client = new WebViewClient() {
/**
* 頁面加載時會回調(diào)該方法,如果用戶同意就會成功獲取code
* 然后發(fā)送一個異步的post請求獲取access_token
* 若成功獲取access_token信息,則保存所有重要信息
* 并跳轉(zhuǎn)到主界面
* @param view 顯現(xiàn)界面視圖
* @param url 加載網(wǎng)址
* @param favicon 網(wǎng)址的相關(guān)圖標
*/
@Override
public void onPageStarted(WebView view, String url, Bitmap favicon) {
if (url.startsWith(Constants.REDIRECT_URL)) {
String code = url.split("=")[1];
//設(shè)置請求參數(shù)
RequestParams params = new RequestParams();
params.put("client_id", Constants.CLIENT_ID);
params.put("client_secret", Constants.APP_SECRET);
params.put("grant_type", "authorization_code");
params.put("redirect_uri", Constants.REDIRECT_URL);
params.put("code", code);
//發(fā)送異步post請求access_token令牌,并保存的OAthu的
// client_id和client_secret和access_token等重要信息
WeiboRestClient.post("oauth2/access_token", params, new AsyncHttpResponseHandler() {
@Override
public void onSuccess(int i, Header[] headers, byte[] bytes) {
String data = new String(bytes);
try {
//服務(wù)器返回數(shù)據(jù)
JSONObject object = new JSONObject(data);
(preferences.edit()).clear();
saveData(object);
Toast.makeText(OAuthActivity.this, "登陸成功", Toast
.LENGTH_SHORT).show();
//進入微博主界面
Intent intent = new Intent(OAuthActivity.this,MainActivity.class);
startActivity(intent);
//關(guān)閉授權(quán)界面
OAuthActivity.this.finish();
} catch (JSONException e) {
e.printStackTrace();
} }
@Override
public void onFailure(int i, Header[] headers, byte[] bytes, Throwable throwable) {
Toast.makeText(OAuthActivity.this, "登陸失敗", Toast.LENGTH_SHORT)
.show();
OAuthActivity.this.finish();
}});}}};
webView.setWebViewClient(client);
}
/**
* 使用SharedPreferences保存的OAthu的client_id和client_secret和access_token等重要信息
*/
private void saveData(JSONObject object) {
try {
SharedPreferences.Editor editor = preferences.edit();
editor.putString("access_token", object.getString("access_token"));
editor.putString("remind_in", object.getString("remind_in"));
editor.putString("expires_in", object.getString("expires_in"));
editor.putString("uid", object.getString("uid"));
editor.putString("client_id", Constants.CLIENT_ID);
editor.putString("redirect_uri", Constants.REDIRECT_URL);
editor.putString("client_secret", Constants.APP_SECRET);
editor.apply();
} catch (JSONException e) {
e.printStackTrace();
} }}
這里的異步請求類WeiboRestClient.java,使用異步發(fā)送HTTP請求,在回調(diào)函數(shù)中處理響應(yīng)HTTP請求過程不在UI線程進行使用線程池來管理并發(fā)數(shù)支持GET/POST請求
public class WeiboRestClient {
private static final String BASE_URL = "https://api.weibo.com/";
private static AsyncHttpClient client = new AsyncHttpClient();
public static void get(String url, RequestParams params, AsyncHttpResponseHandler responseHandler) {
client.get(getAbsoluteUrl(url), params, responseHandler);
}
public static void post(String url, RequestParams params, AsyncHttpResponseHandler responseHandler) {
client.post(getAbsoluteUrl(url), params, responseHandler);
}
private static String getAbsoluteUrl(String relativeUrl) {
return BASE_URL + relativeUrl;
}
}
OAuthActivity的布局webview.xml
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent">
<WebView
android:id="@+id/webView"
android:layout_width="match_parent"
android:layout_height="match_parent"/>
</LinearLayout>

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- Android用戶輸入自動提示控件AutoCompleteTextView使用方法
- Android自動獲取輸入短信驗證碼庫AutoVerifyCode詳解
- Android AutoWrapTextView中英文排版問題的解決方法
- Android中使用 AutoCompleteTextView 實現(xiàn)手機號格式化附帶清空歷史的操作
- Android自動編輯文本框(AutoCompleteTextView)使用方法詳解
- Android中AutoCompleteTextView自動提示
- android中AutoCompleteTextView的簡單用法(實現(xiàn)搜索歷史)
- Android仿百度谷歌搜索自動提示框AutoCompleteTextView簡單應(yīng)用示例
- 關(guān)于Android HTML5 audio autoplay無效問題的解決方案
- Android AutoCompleteTextView自動提示文本框?qū)嵗a
- Android App開發(fā)的自動化測試框架UI Automator使用教程
- Android中AutoCompleteTextView與TextWatcher結(jié)合小實例
- Android AutoValue使用和擴展庫
相關(guān)文章
Android編程使用android-support-design實現(xiàn)MD風格對話框功能示例
這篇文章主要介紹了Android編程使用android-support-design實現(xiàn)MD風格對話框功能,涉及Android對話框、視圖、布局相關(guān)操作技巧,需要的朋友可以參考下2017-01-01
RecyclerView Adapter輔助類詳解及示例代碼
本文主要介紹RecyclerView Adapter輔助類的知識,這里整理了詳細資料及簡單示例代碼,幫助大家學(xué)習(xí)這部分的內(nèi)容,有興趣的小伙伴可以參考下2016-09-09
Android自定義View實現(xiàn)水平帶數(shù)字百分比進度條
這篇文章主要為大家詳細介紹了Android自定義View實現(xiàn)水平帶數(shù)字百分比進度條,具有一定的參考價值,感興趣的小伙伴們可以參考一下2018-12-12
android10 隱藏SystemUI鎖屏下的多用戶圖標的示例代碼
這篇文章主要介紹了android10 隱藏SystemUI鎖屏下的多用戶圖標,本文通過示例代碼給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-12-12
Android實現(xiàn)下載zip壓縮文件并解壓的方法(附源碼)
這篇文章主要給大家介紹了利用Android實現(xiàn)下載zip壓縮文件并解壓的方法,文中給出了示例代碼并提供了源碼下載,需要的朋友可以參考借鑒,下面來一起看看吧。2017-02-02

