Android使用友盟集成QQ、微信、微博等第三方登录
2017-11-20 17:01
936 查看
前言
最近项目需要加入第三方分享和登录功能,之前其他项目的第三方分享和登录一直都使用ShareSDK实现的。为了统一使用友盟的全家桶,所以三方分享和登录也就选择了友盟。这里记录一下完整的集成与使用流程。
1、申请友盟Appkey
直接到友盟官网申请即可。一般都不用自己去申请,跟项目经理要即可。(我这里的Demo为了方便就直接用友盟Demo里面提供的Appkey,但是创建的项目包名也要和友盟一样。真实项目要自己另外申请)
2、下载SDK
下载地址:http://dev.umeng.com/social/android/sdk-download下载的时候根据自己需求进行选择,我这里选择选择的是精简版(包含常用的分享与登录功能),只测试微信,QQ,新浪微博。
下载后解压出来是这样的:
3、准备资源
使用友盟的集成工具快速集成友盟的分享SDK:双击 友盟集成工具.jar–>选择使用的平台和IDE,如图:点击OK键,会在当前目录生成名为umeng_integratetool_result的文件夹,如图:
4、开始集成
1、将上面的文件夹依次粘贴到工程相应的文件夹即可,如图:
2、将debug.keystore文件拷贝到项目的app目录下(对应app build中相应的位置),目的是为了使用友盟的签名,如图:
3、添加回调Activity
1,微信回调:其实在第一步拷贝的时候已经添加了。即在包名目录下创建wxapi文件夹,新建一个名为WXEntryActivity的activity继承WXCallbackActivity
2,QQ与新浪微博的回调:
QQ与新浪不需要添加Activity,但需要在使用QQ分享或者授权的Activity中添加如下代码:
(注意onActivityResult不可在fragment中实现,如果在fragment中调用登录或分享,需要在fragment依赖的Activity中实现)
@Override protected void onActivityResult(int requestCode, int resultCode, Intent data) { super.onActivityResult(requestCode, resultCode, data); UMShareAPI.get(this).onActivityResult(requestCode, resultCode, data); }1
2
3
4
5
[/code]
4、配置清单文件Android Manifest
1,添加权限:<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"/> <uses-permission android:name="android.permission.INTERNET" /> <uses-permission android:name="android.permission.ACCESS_FINE_LOCATION" /> <uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION" /> <uses-permission android:name="android.permission.ACCESS_LOCATION_EXTRA_COMMANDS" />1
2
3
4
5
6
7
8
9
[/code]
2,添加sdk中需要的Activity
<!--微信--> <activity android:name=".wxapi.WXEntryActivity" android:configChanges="keyboardHidden|orientation|screenSize" android:exported="true" android:screenOrientation="portrait" android:theme="@android:style/Theme.Translucent.NoTitleBar"/> <!--新浪微博--> <activity android:name=".WBShareActivity" android:configChanges="keyboardHidden|orientation" android:screenOrientation="portrait"> <intent-filter> <action android:name="com.sina.weibo.sdk.action.ACTION_SDK_REQ_ACTIVITY"/> <category android:name="android.intent.category.DEFAULT"/> </intent-filter> </activity> <!--qq精简版--> <activity android:name="com.umeng.qq.tencent.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"/> <!--这里的scheme是qq分享要用的,100424468为自己申请的appid,真实项目中需要替换--> <data android:scheme="tencent100424468"/> </intent-filter> </activity> <activity android:name="com.umeng.qq.tencent.AssistActivity" android:configChanges="orientation|keyboardHidden|screenSize" android:screenOrientation="portrait" android:theme="@android:style/Theme.Translucent.NoTitleBar"/> <!--分享编辑页--> <activity android:name="com.umeng.socialize.editorpage.ShareActivity" android:excludeFromRecents="true" android:theme="@style/Theme.UMDefault" />1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
[/code]
3,添加友盟appkey
<meta-data android:name="UMENG_APPKEY" android:value="561cae6ae0f55abd990035bf"> </meta-data>1
2
3
4
[/code]
5、配置三方appkey
新建MyApplication继承Application(注意:需要在清单文件中配置该MyApplication),在MyApplication文件中配置三方平台的appkey和初始化sdk。如下:public class MyApplication extends Application { @Override public void onCreate() { super.onCreate(); UMShareAPI.get(this);//初始化sdk //开启debug模式,方便定位错误,具体错误检查方式可以查看http://dev.umeng.com/social/android/quick-integration的报错必看,正式发布,请关闭该模式 Config.DEBUG = true; } //各个平台的配置 { //微信 PlatformConfig.setWeixin("wxdc1e388c3822c80b", "3baf1193c85774b3fd9d18447d76cab0"); //新浪微博(第三个参数为回调地址) PlatformConfig.setSinaWeibo("3921700954", "04b48b094faeb16683c32669824ebdad","http://sns.whalecloud.com/sina2/callback"); //QQ PlatformConfig.setQQZone("100424468", "c7394704798a158208a74ab60104f0ba"); } }1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
[/code]
6、登录代码MainActivity.java:
public class MainActivity extends AppCompatActivity {1
private String TAG = this.getClass().getSimpleName();
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
}
public void qqLogin(View view) {
authorization(SHARE_MEDIA.QQ);
}
public void weiXinLogin(View view) {
authorization(SHARE_MEDIA.WEIXIN);
}
public void sinaLogin(View view) {
authorization(SHARE_MEDIA.SINA);
}
//授权
private void authorization(SHARE_MEDIA share_media) {
UMShareAPI.get(this).getPlatformInfo(this, share_media, new UMAuthListener() {
@Override
public void onStart(SHARE_MEDIA share_media) {
Log.d(TAG, "onStart " + "授权开始");
}
@Override
public void onComplete(SHARE_MEDIA share_media, int i, Map<String, String> map) {
Log.d(TAG, "onComplete " + "授权完成");
//sdk是6.4.4的,但是获取值的时候用的是6.2以前的(access_token)才能获取到值,未知原因
String uid = map.get("uid");
String openid = map.get("openid");//微博没有
String unionid = map.get("unionid");//微博没有
String access_token = map.get("access_token");
String refresh_token = map.get("refresh_token");//微信,qq,微博都没有获取到
String expires_in = map.get("expires_in");
String name = map.get("name");
String gender = map.get("gender");
String iconurl = map.get("iconurl");
Toast.makeText(getApplicationContext(), "name=" + name + ",gender=" + gender, Toast.LENGTH_SHORT).show();
//拿到信息去请求登录接口。。。
}
@Override
public void onError(SHARE_MEDIA share_media, int i, Throwable throwable) {
Log.d(TAG, "onError " + "授权失败");
}
@Override
public void onCancel(SHARE_MEDIA share_media, int i) {
Log.d(TAG, "onCancel " + "授权取消");
}
});
}
@Override protected void onActivityResult(int requestCode, int resultCode, Intent data) { super.onActivityResult(requestCode, resultCode, data); UMShareAPI.get(this).onActivityResult(requestCode, resultCode, data); }
}
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
[/code]
效果如下:
Demo下载地址:https://github.com/wildma/UMengThirdPartyShareLogin
相关文章推荐
- [置顶] Android使用友盟集成QQ、微信、微博等第三方登录
- Android使用友盟集成QQ、微信、微博等第三方分享与登录方法详解
- [置顶] Android使用友盟集成QQ、微信、微博等第三方分享
- Android友盟集成QQ、微信、微博等第三方登录与分享
- Android使用ShareSDK集成QQ、微信、微博等第三方登录
- Android使用ShareSDK集成QQ、微信、微博等第三方登录
- Android 使用shareSDK进行第三方登录失败解决方法(微信,微博,qq)
- Android使用shareSDK第三方登录(qq,微信,微博)
- Android使用ShareSDK集成QQ、微信、微博等第三方分享
- Android应用之——微信微博第三方sdk登录分享使用过程中的一些常见问题
- 史上最详细Android集成QQ,微信,微博分享(不用第三方)持续更新中
- 史上最详细Android集成QQ,微信,微博分享(不用第三方)持续更新中
- android使用友盟实现第三方登录、分享以及微信回调无反应问题解决办法
- 使用ShareSDK完成第三方(QQ、微信、微博)登录和分享
- 史上最详细Android集成QQ,微信,微博分享(不用第三方)持续更新中
- 使用ShareSDK完成第三方(QQ、微信、微博)登录和分享
- android第三方(qq、微信、微博)登录和分享
- 史上最详细Android集成QQ,微信,微博分享(不用第三方)持续更新中
- Android友盟分享集成微信QQ微博分享demo精简版
- Android 第三方QQ、微信、微博登录分享