• This repository has been archived on 09/Sep/2022
  • Stars
    star
    244
  • Rank 165,885 (Top 4 %)
  • Language
    Java
  • License
    Apache License 2.0
  • Created over 7 years ago
  • Updated over 4 years ago

Reviews

There are no reviews yet. Be the first to send feedback to the community and the maintainers!

Repository Details

第三方SDK集成库,授权/分享/支付

sdk3rd

第三方SDK集成库,支持 授权/分享/支付 等功能

  • 授权 目前支持 微信/QQ/新浪微博,客户端只需要配置APPID(新浪微博)
  • 分享 目前支持 微信(会话/朋友圈/收藏),QQ/QZone,新浪微博
  • 支付 目前支持 支付宝/微信支付
  • 对于授权与分享,客户端不用配置APPSECRET,只需要要APPID(新浪微博授权需要redirectUrl)
  • 对于支付,APPID包含在由后端动态返回的paydata里
  • 可注册自定义平台实现,满足特殊需求
  • 分享并未实现ui,需要自己提供ui

screenshot

目前这个库还不稳定,有些细节并未仔细考虑,有些功能也并未进行测试,支持的平台也不多,欢迎大家 star/issue/pr,共同完善这个库

关于授权

成功后的结果为 "code|{code}", "token|{openId}|{token}" 两种形式

  • 微信授权是OAuth2.0返回的授权码(code)
  • QQ授权是SSO返回的是token
  • 微博授权其文档说是支持SSO与OAuth2.0,根据情况可能返回code与token

但客户端其实不需要关心是code还是token,直接把result发结服务端就好了

关于支付

很多支付类库会在客户端处理商品支付信息,其实这是不必要的,直接由服务端返回数据并交给支付SDK,然后处理支付结果就好了

关于分享

支持 纯文本/纯图片/图文/网页/音乐/视频 等分享类型

  • 网页/音乐/视频 是卡片形式,可添加 标题(title)/描述(description)/缩略图(thumb)
  • 微信朋友圈的网页链接不显示 description
  • 新浪微博文本包含的网址会转成链接
  • QZone 的 纯文本/纯图片/图文/视频 以“说说”的形式发布
平台 纯文本 纯图片 图文 网页 音乐 视频
QQ x o x o o x
QZone o o o o x o
WXSession o o x o o o
WXTimeline o o x o o o
Weibo o o o x x x
SendToQQ o o x x x x
SendToWXS o o x x x x
SendToWXT o o x x x x

Demo

运行demo需要在gradle.properties中修改app的包名,签名和为app申请的APPID


APPLICATION_ID=ezy.demo.sdk3rd

APPID_QQ=YOUR_APPID
APPID_WEIXIN=YOUR_APPID
APPID_WEIBO=YOUR_APPID

SINGING_ALIAS=androiddebugkey
SINGING_PASSWORD=android
SINGING_FILE=debug.keystore

使用方法

添加依赖

repositories {
    maven { url "https://jitpack.io" }
}
dependencies {
    compile 'com.github.czy1121.sdk3rd:sdk3rd:0.1.2'
    compile 'com.github.czy1121.sdk3rd:sdk3rd-alipay:0.1.1'
    compile 'com.github.czy1121.sdk3rd:sdk3rd-qq:0.1.0'

    compile 'com.sina.weibo.sdk:core:1.0.0:openDefaultRelease@aar'
    compile 'com.tencent.mm.opensdk:wechat-sdk-android-without-mta:1.0.2'

}

使用配置

配置APPID

PlatformConfig.useQQ(BuildConfig.APPID_QQ);
PlatformConfig.useWeixin(BuildConfig.APPID_WEIXIN);
PlatformConfig.useWeibo(BuildConfig.APPID_WEIBO, "http://www.sina.com/");
PlatformConfig.usePayments();

使用授权SDK

设置全局事件回调(非必要)

AuthorizeSDK.setDefaultCallback(new OnCallback() {
    @Override
    public void onStarted(Activity activity) {
        Log.e("ezy", "authorize started");
    }

    @Override
    public void onCompleted(Activity activity) {
        Log.e("ezy", "authorize completed");
    }

    @Override
    public void onSucceed(Activity activity, Object result) {
        Log.e("ezy", "authorize succeed");
    }

    @Override
    public void onFailed(Activity activity, int code, String message) {
        Log.e("ezy", "authorize failed [" + code + "]" + message);
    }
});

接收授权结果(新浪微博/QQ)

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

调用授权

AuthorizeSDK.authorize(MainActivity.this, platform, new OnSucceed<String>() {
    @Override
    public void onSucceed(String result) {
        Toast.makeText(MainActivity.this, "登陆成功 - " + result, Toast.LENGTH_LONG).show();

    }
});

注册自定义平台,需要实现 IAuthorize 与相应的 IFactory

AuthorizeSDK.register(IFactory<IAuthorize> factory);
AuthorizeSDK.register(String platformName, String appId, Class<IAuthorize> clazz);

使用支付SDK

全局事件回调的设置与授权SDK类似

调用支付

PaymentSDK.pay(MainActivity.this, platform, paydata, new OnSucceed<String>() {
    @Override
    public void onSucceed(String result) {
        // todo
    }
});

注册自定义平台,需要实现 IPayable 与相应的 IFactory

PaymentSDK.register(IFactory<IPayable> factory);
PaymentSDK.register(String platformName, Class<IPayable> clazz);

使用分享SDK

全局事件回调的设置与授权SDK类似

...

分享结果的接收也与授权SDK类似(QQ)

...

注册自定义平台,需要实现 IShareable 与相应的 IFactory

ShareSDK.register(IFactory<IShareable> factory);
ShareSDK.register(String platformName, Class<IShareable> clazz);

分享

// 分享纯文本
ShareSDK.make(this, text).share(platform);
// 分享纯图片
ShareSDK.make(this, new MoImage(image)).share(platform);
// 分享图文
ShareSDK.make(this, text, new MoImage(image)).share(platform);

// 分享网页链接
ShareSDK.make(this, new MoWeb(url))
        .withTitle("这是标题")
        .withDescription("这是摘要")
        .withThumb(thumb)
        .share(platform, new OnSucceed<String>() {
           @Override
           public void onSucceed(String result) {
               Toast.makeText(MainActivity.this, "分享成功", Toast.LENGTH_LONG).show();
           }
        });

// 分享音乐
ShareSDK.make(this, new MoMusic(url))
        .withTitle("这是标题")
        .withDescription("这是摘要")
        .withThumb(thumb)
        .share(platform);

参考

友盟+分享组件90%常见问题汇总 http://bbs.umeng.com/thread-17764-1-1.html

友盟各平台可分享内容预览 http://dev.umeng.com/social/android/share-detail#5

Android 不同平台分享内容的详细说明 http://wiki.mob.com/不同平台分享内容的详细说明

新浪微博SDK https://github.com/sinaweibosdk/weibo_android_sdk

License

Copyright 2017 czy1121

Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at

   http://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.

More Repositories

1

update

清晰灵活简单易用的应用更新库
Kotlin
1,826
star
2

settingscompat

特殊权限(Special Permissions)兼容库,悬浮窗权限(SYSTEM_ALERT_WINDOW)与系统设置修改权限(WRITE_SETTINGS)
Java
951
star
3

loadinglayout

简单实用的页面多状态布局(content,loading,empty,error)
Java
753
star
4

cornerlabelview

角标(corner label)
Java
488
star
5

badgebutton

带有徽标(数字,小红点)的按钮
Java
432
star
6

roundbutton

可设置圆角背景边框的的按钮
Java
310
star
7

noticeview

滚动播放的公告控件
Java
299
star
8

NotificationDemo

通知demo
Java
88
star
9

segmentedview

ios风格的分段控件,类似 UISegmentedControl
Java
61
star
10

ThemeDemo

Databinding+LiveData轻松实现无重启换肤
Kotlin
32
star
11

init

Kotlin + Flow 实现的 Android 应用初始化任务启动库。
Kotlin
24
star
12

readmoretextview

点击展开收缩的文本
Java
20
star
13

numberstepper

number stepper
Java
16
star
14

httpapi

使用 Coroutine + Retrofit 打造的最简单HTTP请求库
Kotlin
11
star
15

systembars

系统栏工具库 - 状态栏/导航栏/沉浸式
Kotlin
10
star
16

subtextview

带副文本(副标题,值)的 TextView
Java
7
star
17

router

一个 kotlin + ksp 实现的路由库,通过 uri 实现页面间跳转
Kotlin
6
star
18

deviceid

获取设备标识(widevineId/instanceId/androidId/oaid),采集设备信息。
Kotlin
6
star
19

LauncherIconPlugin

Android小工具,当构建类型不为release时,在启动图标上显示添加 版本/分支/时间 等信息
Groovy
5
star
20

webcache

Android WebView 缓存管理,提升网页打开速度。
Kotlin
3
star
21

flowbus

事件总线(基于SharedFlow)
Kotlin
3
star
22

scrollinglayout

垂直方向支持多个子视图持续连贯滚动的容器,并且支持吸顶功能。
Kotlin
3
star
23

tv

一些实用的自定义TextView
Kotlin
2
star
24

servicelocator

一个简单的服务定位器模式实现,如果觉得Dagger/Koin太重,可以试试这个。
Kotlin
2
star
25

networkstate

判断网络是否可用,判断网络(wifi/mobile/vpn)是否连接,获取网络类型,监听网络可用事件
Kotlin
2
star
26

binding

简化 DataBinding/ViewBinding 使用,提供生命周期感知能力,支持多种使用环境(ComponentActivity/Fragment/CustomDialog/ViewGroup)
Kotlin
2
star
27

bk

BKDrawable/BKFrameLayout/BKLinearLayout/BKTextView 可自定义 背景色/渐变/圆角/阴影/描边
Kotlin
2
star
28

statelayout

简单实用无侵入高扩展的页面多状态布局(content,loading,empty,error)
Kotlin
2
star
29

base

页面基类 BaseActivity/BaseFragment 统一了子类初始化UI(onSetupUI)的位置
Kotlin
1
star
30

majia

将指定的包中的类移到新包名下,通过简单的配置就可以生成马甲包。
Kotlin
1
star
31

jsbridge

简单易用的 Android WebView 和 Javascript 交互框架。
Kotlin
1
star
32

dag

有向无环图(DAG),可用来调度应用初始化任务
Kotlin
1
star
33

ecrontab

crontab for erlang, @author litao cheng <[email protected]>
Erlang
1
star
34

mmkv

使用 kotlin 委托属性封装的 mmkv 库,代替 SharedPreferences,简单好用
Kotlin
1
star
35

argument

通过 Kotlin 委托属性获取 Activity/Fragment 的参数
Kotlin
1
star
36

pullrefresh

实现了嵌套滚动机制的下拉刷新控件。
Kotlin
1
star
37

dialog

AlertDialog扩展(tip/alert/confirm/choose) 自定义对话框(CustomDialog/BottomDialog/DropdownDialog/SideDialog) LoadingDialog/InputDialog/ActionSheetDialog/PickerDialog
Kotlin
1
star
38

loading

一些 loading 动画
Kotlin
1
star
39

webview

jsbridge 和 WebView 资源包管理
Kotlin
1
star