All Projects → czy1121 → Sdk3rd

czy1121 / Sdk3rd

Licence: apache-2.0
第三方SDK集成库,授权/分享/支付

Programming Languages

java
68154 projects - #9 most used programming language

Projects that are alternatives of or similar to Sdk3rd

YHThirdManager
一个快速、简单、易集成、扩展性好的社交化组件。摒弃友盟等三方库,使用原生SDK。支持微信支付、微信分享、微信登录、微信授权、QQ授权、QQ分享、QQ登录、新浪授权、新浪登录、新浪分享、微博评论、微博获取、支付宝支付。极大的减小了包体积;同时加入了自动管理提示框的功能
Stars: ✭ 41 (-83.53%)
Mutual labels:  share, login, alipay, weixin, weibo, qq
Socialsdklibrary
提供微博、微信、QQ、Tim、QQ 轻聊版、钉钉的登陆分享功能支持;
Stars: ✭ 399 (+60.24%)
Mutual labels:  share, qq, login, wechat, weibo
Socialite
Socialite is an OAuth2 Authentication tool. It is inspired by laravel/socialite, you can easily use it without Laravel.
Stars: ✭ 1,026 (+312.05%)
Mutual labels:  alipay, qq, login, wechat, weibo
Monkeyking
MonkeyKing helps you to post messages to Chinese Social Networks.
Stars: ✭ 2,699 (+983.94%)
Mutual labels:  alipay, qq, wechat, weibo
Wechat kit
flutter版微信登录/分享/支付
Stars: ✭ 347 (+39.36%)
Mutual labels:  share, login, wechat, weixin
Pay
可能是我用过的最优雅的 Alipay 和 WeChat 的支付 SDK 扩展包了
Stars: ✭ 4,176 (+1577.11%)
Mutual labels:  payment, alipay, wechat, weixin
Sns auth
通用第三方登录SDK,支持微信,微信扫码,QQ,微博登录,支付宝登录,Facebook,Line,Twitter,Google
Stars: ✭ 520 (+108.84%)
Mutual labels:  alipay, qq, wechat, weixin
Weixin Pay
微信支付
Stars: ✭ 863 (+246.59%)
Mutual labels:  payment, wechat, weixin
Paylink
Paylink 是基于 .NET Core 、 ASP.NET Core 开发的支付SDK集,它极大简化了API调用及通知的处理流程。
Stars: ✭ 947 (+280.32%)
Mutual labels:  payment, alipay, weixin
Wechat
weixin/wechat/微信公众平台/微信企业号/微信商户平台/微信支付 go/golang sdk
Stars: ✭ 2,330 (+835.74%)
Mutual labels:  sdk, wechat, weixin
Gopay
QQ、微信(WeChat)、支付宝(AliPay)的Go版本SDK。【微信支付V3已支持,推荐使用微信V3接口】
Stars: ✭ 1,034 (+315.26%)
Mutual labels:  alipay, qq, wechat
Laravel Pay
可能是我用过的最优雅的 Alipay 和 WeChat 的 laravel 支付扩展包了
Stars: ✭ 856 (+243.78%)
Mutual labels:  payment, alipay, wechat
Weixinmpsdk
微信全平台 SDK Senparc.Weixin for C#,支持 .NET Framework 及 .NET Core、.NET 6.0。已支持微信公众号、小程序、小游戏、企业号、企业微信、开放平台、微信支付、JSSDK、微信周边等全平台。 WeChat SDK for C#.
Stars: ✭ 7,098 (+2750.6%)
Mutual labels:  sdk, wechat, weixin
Diplomat
整合第三方 SDK 微信、微博、 QQ 等为统一的 Diplomat 接口。
Stars: ✭ 672 (+169.88%)
Mutual labels:  qq, wechat, weibo
Node Tenpay
微信支付 for nodejs
Stars: ✭ 947 (+280.32%)
Mutual labels:  payment, wechat, weixin
L Passport
Koa middleware and api sdk for wechat oauth, qq oauth, baidu oauth and weibo oauth
Stars: ✭ 52 (-79.12%)
Mutual labels:  qq, wechat, weibo
Lcactionsheet
一款简约而不失强大的 ActionSheet,微博、微信和 QQ 都采用了极其类似的样式,完全支持 Swift。
Stars: ✭ 809 (+224.9%)
Mutual labels:  qq, wechat, weibo
Lxspider
爬虫案例合集。包括但不限于《淘宝、京东、天猫、豆瓣、抖音、快手、微博、微信、阿里、头条、pdd、优酷、爱奇艺、携程、12306、58、搜狐、百度指数、维普万方、Zlibraty、Oalib、小说、招标网、采购网、小红书》
Stars: ✭ 60 (-75.9%)
Mutual labels:  wechat, weixin, weibo
Wxjava
Wechat-Group/WxJava的备份,有问题请到对应项目下讨论
Stars: ✭ 56 (-77.51%)
Mutual labels:  sdk, wechat, weixin
Teepay
Typecho 个人支付宝、微信收款插件
Stars: ✭ 90 (-63.86%)
Mutual labels:  alipay, wechat, weixin

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:[email protected]'
    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.
Note that the project description data, including the texts, logos, images, and/or trademarks, for each open source project belongs to its rightful owner. If you wish to add or remove any projects, please contact us at [email protected].