700字范文,内容丰富有趣,生活中的好帮手!
700字范文 > Android中的友盟(微信 QQ 新浪)第三方登录分享

Android中的友盟(微信 QQ 新浪)第三方登录分享

时间:2024-07-19 01:29:56

相关推荐

Android中的友盟(微信 QQ 新浪)第三方登录分享

前言:我再这里只总结Android开发人员需要做的,其他的就去看开发文档吧,例如获取Appkey,就找你的领导要去吧。

一、准备工作

第一步:快速集成。

快速集成包含自动集成与手动集成两种方式,开发者可以根据自身情况选择一种集成方式即可。

1.自动集成:maven中心库在线依赖

通过在Android Studio工程build.gradle配置脚本中添加maven线上依赖,导入最新版本组件化基础库。

在Gradle依赖中添加:

dependencies {compile 'com.umeng.sdk:common:latest.integration'compile 'com.umeng.sdk:utdid:1.1.5.3'}

如果无法正常集成请添加如下配置:

allprojects {repositories {mavenCentral()}}

在Android Studio 3.1及以上版本中添加maven依赖

在Android Studio 3.1及以上版本开发环境下,指定引用最新版本依赖写法”latest.integration”可能导致下载库超时,此时需要指定具体版本号。

dependencies {compile 'com.umeng.sdk:common:1.5.0'compile 'com.umeng.sdk:utdid:1.1.5.3'}

2.手动集成:访问【友盟+】官网组件化SDK下载地址,选择Android平台下载页面,选择对应业务SDK进行下载,这里用到的也就是社会化分享 SDK(第三个),旁边的设置,就是你要选择的第三方登录分享的方式,最后选中点击下载。

只需把common和share文件夹中的jar包和相应的资源文件导入工程中即可。

第二步:添加权限。

请在AndroidManifest中添加如下权限:

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

如果需要使用QQ纯图分享或避免其它平台纯图分享的时候图片不被压缩,可以增加以下权限:

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

第三步:记得Android6.0权限适配。

请查看你的build.gradle文件,如果targetSdkVersion小于或等于22,可以忽略这一步,如果大于或等于23,需要做权限的动态申请:

if(Build.VERSION.SDK_INT>=23){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);}

其中123是requestcode,可以根据这个code判断,用户是否同意了授权。如果没有同意,可以根据回调进行相应处理:

@Overridepublic void onRequestPermissionsResult(int requestCode,String permissions[], int[] grantResults) {}

第四步:添加回调Activity,我在这里只添加微信、QQ、新浪,其他的去看开发文档吧。

微信

在包名目录下创建wxapi文件夹,新建一个名为WXEntryActivity的activity继承WXCallbackActivity

QQ与新浪

QQ与新浪不需要添加Activity,但需要在使用QQ分享或者授权的Activity中,添加:

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

注意onActivityResult不可在fragment中实现,如果在fragment中调用登录或分享,需要在fragment依赖的Activity中实现

第五步:配置Android Manifest XML,这里也是配置三种,其他的看开发文档。

新浪:

<activityandroid:name="com.umeng.socialize.media.WBShareCallBackActivity"android:configChanges="keyboardHidden|orientation"android:theme="@android:style/Theme.Translucent.NoTitleBar"android:exported="false"></activity><activity android:name="com.sina.weibo.sdk.web.WeiboSdkWebActivity"android:configChanges="keyboardHidden|orientation"android:exported="false"android:windowSoftInputMode="adjustResize"></activity><activityandroid:theme="@android:style/Theme.Translucent.NoTitleBar.Fullscreen"android:launchMode="singleTask"android:name="com.sina.weibo.sdk.share.WbShareTransActivity"><intent-filter><action android:name="com.sina.weibo.sdk.action.ACTION_SDK_REQ_ACTIVITY" /><category android:name="android.intent.category.DEFAULT" /></intent-filter></activity>

微信:

<activityandroid:name=".wxapi.WXEntryActivity"android:configChanges="keyboardHidden|orientation|screenSize"android:exported="true"android:theme="@android:style/Theme.Translucent.NoTitleBar" />

QQ(请注意将我们的qq appkey替换成您自己的qq appkey):

<activityandroid: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><activityandroid:name="com.mon.AssistActivity"android:theme="@android:style/Theme.Translucent.NoTitleBar"android:configChanges="orientation|keyboardHidden|screenSize"/>

分享编辑页(只有豆瓣,人人,腾讯微博,领英,twitter需要):

<activityandroid:name="com.umeng.socialize.editorpage.ShareActivity"android:theme="@android:style/Theme.NoTitleBar"android:excludeFromRecents="true"/>

第六步:初始化设置。

初始化需要在您的Application中调用我们的初始化接口:

@Overridepublic void onCreate() {super.onCreate();UMConfigure.init(this,"5a12384aa40fa3551f0001d1","umeng",UMConfigure.DEVICE_TYPE_PHONE,"");//58edcfeb310c93091c000be2 5965ee00734be40b580001a0}

更多了解初始化接口可以参照文档,接下来需要设置各个平台的appkey,选择您需要的:

PlatformConfig.setWeixin("wxdc1e388c3822c80b", "3baf1193c85774b3fd9d18447d76cab0");//豆瓣RENREN平台目前只能在服务器端配置PlatformConfig.setSinaWeibo("3921700954", "04b48b094faeb16683c32669824ebdad","");PlatformConfig.setYixin("yxc0614e80c9304c11b0391514d09f13bf");PlatformConfig.setQQZone("100424468", "c7394704798a158208a74ab60104f0ba");PlatformConfig.setTwitter("3aIN7fuF685MuZ7jtXkQxalyi", "MK6FEYG63eWcpDFgRYw4w9puJhzDl0tyuqWjZ3M7XJuuG7mMbO");PlatformConfig.setAlipay("111700822536");PlatformConfig.setLaiwang("laiwangd497e70d4", "d497e70d4c3e4efeab1381476bac4c5e");PlatformConfig.setPinterest("1439206");PlatformConfig.setKakao("e4f60e065048eb031e235c806b31c70f");PlatformConfig.setDing("dingoalmlnohc0wggfedpk");PlatformConfig.setVKontakte("5764965","5My6SNliAaLxEm3Lyd9J");PlatformConfig.setDropbox("oz8v5apet3arcdy","h7p2pjbzkkxt02a");PlatformConfig.setYnote("9c82bf470cba7bd2f1819b0ee26f86c6ce670e9b");

第七步:签名配置。

将文件夹中的签名文件放入到工程中,例如我的签名文件是debug.keystore

然后增加签名文件的密码:

signingConfigs {debug {storeFile file('debug.keystore')storePassword "android"keyAlias "androiddebugkey"keyPassword "android"}}

然后在buildTypes中将这个signingConfigs配置进去,签名文件如果不加,部分平台的授权会受到影响。如下图所示:

第八步:混淆配置。

-dontshrink-dontoptimize-dontwarn com.google.android.maps.**-dontwarn android.webkit.WebView-dontwarn com.umeng.**-dontwarn com.tencent.weibo.sdk.**-dontwarn com.facebook.**-keep public class javax.**-keep public class android.webkit.**-dontwarn android.support.v4.**-keep enum com.facebook.**-keepattributes Exceptions,InnerClasses,Signature-keepattributes *Annotation*-keepattributes SourceFile,LineNumberTable-keep public interface com.facebook.**-keep public interface com.tencent.**-keep public interface com.umeng.socialize.**-keep public interface com.umeng.socialize.sensor.**-keep public interface com.umeng.scrshot.**-keep public class com.umeng.socialize.* {*;}-keep class com.facebook.**-keep class com.facebook.** { *; }-keep class com.umeng.scrshot.**-keep public class com.tencent.** {*;}-keep class com.umeng.socialize.sensor.**-keep class com.umeng.socialize.handler.**-keep class com.umeng.socialize.handler.*-keep class com.umeng.weixin.handler.**-keep class com.umeng.weixin.handler.*-keep class com.umeng.qq.handler.**-keep class com.umeng.qq.handler.*-keep class UMMoreHandler{*;}-keep class com.tencent.mm.sdk.modelmsg.WXMediaMessage {*;}-keep class com.tencent.mm.sdk.modelmsg.** implements com.tencent.mm.sdk.modelmsg.WXMediaMessage$IMediaObject {*;}-keep class im.yixin.sdk.api.YXMessage {*;}-keep class im.yixin.sdk.api.** implements im.yixin.sdk.api.YXMessage$YXMessageData{*;}-keep class com.tencent.mm.sdk.** {*;}-keep class com.tencent.mm.opensdk.** {*;}-keep class com.tencent.wxop.** {*;}-keep class com.tencent.mm.sdk.** {*;}-dontwarn twitter4j.**-keep class twitter4j.** { *; }-keep class com.tencent.** {*;}-dontwarn com.tencent.**-keep class com.kakao.** {*;}-dontwarn com.kakao.**-keep public class .umeng.soexample.R$*{public static final int *;}-keep public class com.linkedin.android.mobilesdk.R$*{public static final int *;}-keepclassmembers enum * {public static **[] values();public static ** valueOf(java.lang.String);}-keep class com.tencent.open.TDialog$*-keep class com.tencent.open.TDialog$* {*;}-keep class com.tencent.open.PKDialog-keep class com.tencent.open.PKDialog {*;}-keep class com.tencent.open.PKDialog$*-keep class com.tencent.open.PKDialog$* {*;}-keep class com.umeng.socialize.impl.ImageImpl {*;}-keep class com.sina.** {*;}-dontwarn com.sina.**-keep class com.alipay.share.sdk.** {*;}-keepnames class * implements android.os.Parcelable {public static final ** CREATOR;}-keep class com.linkedin.** { *; }-keep class com.android.dingtalk.share.ddsharemodule.** { *; }-keepattributes Signature

二、分享

我做了个分享链接的工具类,根据自己的情况自行添加其他分享内容。

public class ShareUtils {private static BaseActivity mActivity;private static ShareUtils shareUtils;public static ShareUtils getInstance(BaseActivity activity) {mActivity = activity;return shapeUtils = new ShareUtils();}private UMShareListener shareListener = new UMShareListener() {/*** @descrption 分享开始的回调* @param platform 平台类型*/@Overridepublic void onStart(SHARE_MEDIA platform) {}/*** @descrption 分享成功的回调* @param platform 平台类型*/@Overridepublic void onResult(SHARE_MEDIA platform) {Toast.makeText(mActivity,"成功了",Toast.LENGTH_LONG).show();}/*** @descrption 分享失败的回调* @param platform 平台类型* @param t 错误原因*/@Overridepublic void onError(SHARE_MEDIA platform, Throwable t) {Toast.makeText(mActivity,"失败"+t.getMessage(),Toast.LENGTH_LONG).show();}/*** @descrption 分享取消的回调* @param platform 平台类型*/@Overridepublic void onCancel(SHARE_MEDIA platform) {Toast.makeText(mActivity,"取消了",Toast.LENGTH_LONG).show();}};/*** 分享*/public void share(String uri){UMImage image = new UMImage(mActivity, R.mipmap.app);final UMWeb web = new UMWeb(uri);//你要分享的链接内容web.setTitle("标题");//标题web.setThumb(image); //缩略图web.setDescription("描述");//描述new ShareAction(mActivity).setDisplayList(SHARE_MEDIA.WEIXIN, SHARE_MEDIA.WEIXIN_CIRCLE, SHARE_MEDIA.QQ, SHARE_MEDIA.QZONE, SHARE_MEDIA.SINA)//分享的枚举变量.setShareboardclickCallback(new ShareBoardlistener() {@Overridepublic void onclick(SnsPlatform snsPlatform, SHARE_MEDIA share_media) {new ShareAction(mActivity).withMedia(web).setPlatform(share_media).setCallback(shareListener)//回调监听对象.share();}}).open();}}}

三、登录

获取用户资料可以使用如下接口:

/*** 1.上下文* 2.登录方式的枚举变量* 3.回调监听对象*/mShareAPI.getPlatformInfo(UserinfoActivity.this, SHARE_MEDIA.SINA, umAuthListener);

其中umAuthListener为授权回调,构建如下:

UMAuthListener authListener = new UMAuthListener() {/*** @desc 授权开始的回调* @param platform 平台名称*/@Overridepublic void onStart(SHARE_MEDIA platform) {}/*** @desc 授权成功的回调* @param platform 平台名称* @param action 行为序号,开发者用不上* @param data 用户资料返回*/@Overridepublic void onComplete(SHARE_MEDIA platform, int action, Map<String, String> data) {Toast.makeText(mContext, "成功了", Toast.LENGTH_LONG).show();}/*** @desc 授权失败的回调* @param platform 平台名称* @param action 行为序号,开发者用不上* @param t 错误原因*/@Overridepublic void onError(SHARE_MEDIA platform, int action, Throwable t) {Toast.makeText(mContext, "失败:" + t.getMessage(), Toast.LENGTH_LONG).show();}/*** @desc 授权取消的回调* @param platform 平台名称* @param action 行为序号,开发者用不上*/@Overridepublic void onCancel(SHARE_MEDIA platform, int action) {Toast.makeText(mContext, "取消了", Toast.LENGTH_LONG).show();}};

登录成功后,第三方平台会将用户资料传回,全部会在Map data中返回,由于各个平台对于用户资料的标识不同,因此为了便于开发者使用,我们将一些常用的字段做了统一封装,开发者可以直接获取,不再需要对不同平台的不同字段名做转换,这里列出我们封装的字段及含义。

删除授权

对于退出登录,想要删除授权的用户可以使用如下接口:

UMShareAPI.get(mContext).deleteOauth(Activity, Platform, authListener);

其中第一个参数为Context;第二个参数为平台,第三个参数为删除授权的回调。

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。