集成友盟第三方QQ登錄

1.創建自己的產品得到對應的appkey
2.導入jar包與資源文件

在這裏插入圖片描述
在這裏插入圖片描述

在這裏插入圖片描述

找到下載的文件中的res文件,將其中的文件全部導入項目中

3.配置清單文件

權限

 <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.ACCESS_COARSE_LOCATION" />
    <uses-permission android:name="android.permission.ACCESS_FINE_LOCATION" />
    <uses-permission android:name="android.permission.CHANGE_WIFI_STATE" />
    <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />

加載產品的id和appkey

配置在application標籤中

<application>
......
<meta-data android:value="5c4091bbf1f556133300037c" android:name="UMENG_APPKEY"/>
<meta-data android:value="UMeng" android:name="UMENG_CHANNEL"/>
.......
</application>

註冊QQ需要的Activity

<!--QQ配置的內容-->
        <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:configChanges="orientation|keyboardHidden|screenSize"
            android:theme="@android:style/Theme.Translucent.NoTitleBar" />

注意,application我們使用的是自己的,所以在清單文件中要聲明一下

<application
android:name=".ui.mycontext.MyContext"
.......>
..............
</applocation>

4.全局自定義application類

初始化appkey,id
初始化平臺

public class MyContext extends Application {

    @Override
    public void onCreate() {
        super.onCreate();

        /*
注意: 即使您已經在AndroidManifest.xml中配置過appkey和channel值,也需要在App代碼中調用初始化接口(如需要使用AndroidManifest.xml中配置好的appkey和channel值,UMConfigure.init調用中appkey和channel參數請置爲null)。
*/
        UMConfigure.init(this, "5c4091bbf1f556133300037c", "UMeng", UMConfigure.DEVICE_TYPE_PHONE,null);

        PlatformConfig.setWeixin("wxdc1e388c3822c80b", "3baf1193c85774b3fd9d18447d76cab0");
        //豆瓣RENREN平臺目前只能在服務器端配置
        PlatformConfig.setSinaWeibo("3921700954", "04b48b094faeb16683c32669824ebdad","http://sns.whalecloud.com");
        PlatformConfig.setYixin("yxc0614e80c9304c11b0391514d09f13bf");
        PlatformConfig.setQQZone("100424468", "c7394704798a158208a74ab60104f0ba");
        PlatformConfig.setTwitter("3aIN7fuF685MuZ7jtXkQxalyi", "MK6FEYG63eWcpDFgRYw4w9puJhzDl0tyuqWjZ3M7XJuuG7mMbO");
        PlatformConfig.setAlipay("2015111700822536");
        PlatformConfig.setLaiwang("laiwangd497e70d4", "d497e70d4c3e4efeab1381476bac4c5e");
        PlatformConfig.setPinterest("1439206");
        PlatformConfig.setKakao("e4f60e065048eb031e235c806b31c70f");
        PlatformConfig.setDing("dingoalmlnohc0wggfedpk");
        PlatformConfig.setVKontakte("5764965","5My6SNliAaLxEm3Lyd9J");
        PlatformConfig.setDropbox("oz8v5apet3arcdy","h7p2pjbzkkxt02a");
    }
}

5.activity代碼部分,點擊自定義button

SHARE_MEDIA.QQ:登錄的方式爲QQ,因爲項目中沒有配置別的三方登錄資源
authListener:這個是回調監聽

點擊登錄

   case R.id.QQLoginButon:
         UMShareAPI mShareAPI = UMShareAPI.get(this);
         mShareAPI.getPlatformInfo(this, SHARE_MEDIA.QQ, authListener);
          break;

回調監聽

登錄成功後,可以加載用戶的頭像.性別.暱稱等等,是一個Map形式的

官方:登錄成功後,第三方平臺會將用戶資料傳回, 全部會在Map data中返回 ,由於各個平臺對於用戶資料的標識不同,因此爲了便於開發者使用,我們將一些常用的字段做了統一封裝,開發者可以直接獲取,不再需要對不同平臺的不同字段名做轉換,這裏列出我們封裝的字段及含義。

在這裏插入圖片描述

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(LoginActivity.this, "成功了", Toast.LENGTH_LONG).show();
            Glide.with(LoginActivity.this).load(data.get("iconurl")).into(qqImg);
        }

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

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

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

重寫onActivityResult方法

@Override
    protected void onActivityResult(int requestCode, int resultCode, Intent data) {
        super.onActivityResult(requestCode, resultCode, data);
        UMShareAPI.get(this).onActivityResult(requestCode, resultCode, data);
    }
``
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章