android 友盟第三方登錄

 

一、要點:介紹友盟,分析第三方登陸流程(以QQ爲例)

        友盟是一個數據統計網站,提供給一些網站的統計代碼來統計網站的訪問情況等,國內是比較知名的統計網站和工具

        也可以幫助我們實現第三方登錄等功能

二、友盟QQ登錄集成

         1.進入友盟官網:https://www.umeng.com/

         2.下載SDK

         ①找到SDK下載

 

 

         ②如圖下載SDK

 

 

 

3.下載完SDK後會出現一個壓縮包將壓縮包中的文件拷貝到對應的文件夾;

   右擊 add as library

 

4.創建一個類繼承Application,並添加如下代碼:

UMConfigure.init(this,"你項目的AppKey","發佈渠道如:小米",UMConfigure.DEVICE_TYPE_PHONE,"");
/**
 * 設置組件化的Log開關
 * 參數: boolean 默認爲false,如需查看LOG設置爲true
 */
UMConfigure.setLogEnabled(true);
PlatformConfig.setQQZone("100424468", "你項目的AppKey");

 

5.AndroidManifest.xml清單文件裏面增加:

在application中添加你的繼承Application類

<application

android:name="你繼承Application的類名"


<!-- 必須的權限 -->
<uses-permission android:name="android.permission.INTERNET"/>

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

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

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

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

<uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE"/>
<activity
    android:name="com.tencent.tauth.AuthActivity"
    android:launchMode="singleTask"
    android:noHistory="true" >
    <intent-filter>
        <action android:name="android.intent.action.VIEW" />

        <category android:name="android.intent.category.DEFAULT" />
        <category android:name="android.intent.category.BROWSABLE" />

        <data android:scheme="tencent100424468" />
    </intent-filter>
</activity>
<activity
    android:name="com.tencent.connect.common.AssistActivity"
    android:theme="@android:style/Theme.Translucent.NoTitleBar"
    android:configChanges="orientation|keyboardHidden|screenSize"/>

6.在實現第三方登錄的activity中先動態申請權限


            if(Build.VERSION.SDK_INT>=23){//QQ需要申請寫入權限
                String[] mPermissionList = new String[]{Manifest.permission.WRITE_EXTERNAL_STORAGE,Manifest.permission.ACCESS_FINE_LOCATION,Manifest.permission.CALL_PHONE,Manifest.permission.READ_LOGS,Manifest.permission.READ_PHONE_STATE, Manifest.permission.READ_EXTERNAL_STORAGE,Manifest.permission.SET_DEBUG_APP,Manifest.permission.SYSTEM_ALERT_WINDOW,Manifest.permission.GET_ACCOUNTS,Manifest.permission.WRITE_APN_SETTINGS};
                ActivityCompat.requestPermissions(this,mPermissionList,123);
            }else{
                UMShareAPI.get(this).getPlatformInfo(this, SHARE_MEDIA.QQ, authListener);
            }
            //點擊註冊按鈕

7.然後重寫onActivtyResult和onRequestPermissionsResult

@Override
public void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions, @NonNull int[] grantResults) {
    super.onRequestPermissionsResult(requestCode, permissions, grantResults);
    if (requestCode==123){
        UMShareAPI.get(this).getPlatformInfo(this, SHARE_MEDIA.QQ, authListener);
    }
}

@Override
protected void onActivityResult(int requestCode, int resultCode, Intent data) {
    super.onActivityResult(requestCode, resultCode, data);
    UMShareAPI.get(this).onActivityResult(requestCode, resultCode, data);
}

8.添加登錄監聽

UMAuthListener authListener = new UMAuthListener() {
        /**
         * @desc 授權開始的回調
         * @param platform 平臺名稱
         */
        @Override
        public void onStart(SHARE_MEDIA platform) {

        }

        /**
         * @desc 授權成功的回調
         * @param platform 平臺名稱
         * @param action 行爲序號,開發者用不上
         * @param data 用戶資料返回
         */
        @Override
        public void onComplete(SHARE_MEDIA platform, int action, Map<String, String> data) {

            Toast.makeText(mContext, "成功了", Toast.LENGTH_LONG).show();
            //跳轉頁面
            startActivity(new Intent("當前的activity", "要跳轉的activity"));

       }

        /**
         * @desc 授權失敗的回調
         * @param platform 平臺名稱
         * @param action 行爲序號,開發者用不上
         * @param t 錯誤原因
         */
        @Override
       public void onError(SHARE_MEDIA platform, int action, Throwable t) {

           Toast.makeText(mContext, "失敗:" + t.getMessage(),                                     Toast.LENGTH_LONG).show();
        }

        /**
         * @desc 授權取消的回調
         * @param platform 平臺名稱
         * @param action 行爲序號,開發者用不上
         */
        @Override
        public void onCancel(SHARE_MEDIA platform, int action) {
            Toast.makeText(mContext, "取消了", Toast.LENGTH_LONG).show();
        }
    };

以上代碼出現一個問題:  友盟第三方登錄後,哪怕你卸載了微博/qq這些客戶端,你點擊上次登錄的方式還是能正常登錄的,不需要重新授權。。導致一個問題,比如我先用這個QQ登錄 後,想換另外一個QQ登錄會導致無法登錄,哪怕退出QQ,卸載客戶端,還是能夠成功授權。

UMShareConfig config = new UMShareConfig();
config.isNeedAuthOnGetUserInfo(true);
UMShareAPI.get(this).setShareConfig(config);


在調取第三方登錄接口前加上前面幾句,這樣每次登錄都會重新調取授權,可以切換第三方賬號
原博主:https://blog.csdn.net/qq_16624353/article/details/80018169

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章