All Projects → NFLeo → ShareLoginPayUtil

NFLeo / ShareLoginPayUtil

Licence: Apache-2.0 License
原生三方(QQ、微信、微博、Instagram、Google、FaceBook)登陆,(QQ、微信、微博、系统)分享,(微信、支付宝)支付

Programming Languages

java
68154 projects - #9 most used programming language

Labels

Projects that are alternatives of or similar to ShareLoginPayUtil

RxValidationTextInputLayout
The easiest way to bring validation to your project
Stars: ✭ 45 (+73.08%)
Mutual labels:  rxjava
RxCoroutineSchedulers
Kotlin Coroutines as RxJava Schedulers 😈
Stars: ✭ 31 (+19.23%)
Mutual labels:  rxjava
dropwizard-mongo
A Dropwizard bundle for MongoDB
Stars: ✭ 20 (-23.08%)
Mutual labels:  rxjava
ReactiveBus
🚍 Reactive Event Bus for JVM (1.7+) and Android apps built with RxJava 2
Stars: ✭ 17 (-34.62%)
Mutual labels:  rxjava
Fineract-CN-mobile
DEPRECATED project - Check the Apache fineract-cn-mobile project instead
Stars: ✭ 17 (-34.62%)
Mutual labels:  rxjava
servant
Serving you with GoogleApiClients any way you like them
Stars: ✭ 17 (-34.62%)
Mutual labels:  rxjava
nakadi-java
🌀 Client library for the Nakadi Event Broker (examples: http://bit.ly/njc-examples, site: https://dehora.github.io/nakadi-java/)
Stars: ✭ 29 (+11.54%)
Mutual labels:  rxjava
RxFbLiveVideoEmoticons
Demo of Fb Live Video Reactions using RxJava2
Stars: ✭ 93 (+257.69%)
Mutual labels:  rxjava
RxFBase
🔥 wrapping firebase with rx
Stars: ✭ 12 (-53.85%)
Mutual labels:  rxjava
TMDB-App
Demo app using TMDB api
Stars: ✭ 13 (-50%)
Mutual labels:  rxjava
Kotlin-Starter
☕ Kotlin starter with rx
Stars: ✭ 22 (-15.38%)
Mutual labels:  rxjava
rx-docker-client
RxJava based Docker REST API client for the JVM
Stars: ✭ 61 (+134.62%)
Mutual labels:  rxjava
Android-RxFirebase
RxJava implementation for the Android Firebase client by Ezhome
Stars: ✭ 30 (+15.38%)
Mutual labels:  rxjava
WanAndroid-Java
一款采用Java语言、MVVM + Retrofit + RxJava架构开发的玩Android客户端 (https://www.wanandroid.com/) 。PS: Kotlin版 (https://github.com/chongyucaiyan/WanAndroid-Kotlin) 。
Stars: ✭ 32 (+23.08%)
Mutual labels:  rxjava
android-online-course
Android Online Course
Stars: ✭ 22 (-15.38%)
Mutual labels:  rxjava
SQLitePractice
数据库案例:1.使用时间和日期函数,增,查时间字段。2.利用ContentProvider,CursorLoader,SQLite实现数据库的观察者模式。3.RxJava,SQLBrite实现数据库的观察者模式。4.拷贝外部db文件到数据库中
Stars: ✭ 21 (-19.23%)
Mutual labels:  rxjava
WanAndroid
Kotlin版 玩Android 客户端
Stars: ✭ 37 (+42.31%)
Mutual labels:  rxjava
RxBilling
Reactive wrapper around the Android Billing API
Stars: ✭ 12 (-53.85%)
Mutual labels:  rxjava
Dribbbler
A Dribbble client with MVP+Repository pattern , RxJava ,Retrofit , Dagger
Stars: ✭ 56 (+115.38%)
Mutual labels:  rxjava
Eyepetizer
An unofficial Eyepetizer(开眼视频) App built using Ijkplayer, RxJava2, Retrofit2, Dagger2, Room , DataBinding and Clean-MVVM Architecture.
Stars: ✭ 22 (-15.38%)
Mutual labels:  rxjava

改自https://github.com/shaohui10086/ShareUtil ,在其基础上添加些许功能及优化,改动如下:

    1. 使用rxjava2
    2. 添加小程序分享支持
    3. 部分代码优化
    4. 添加微信、支付宝支付,避免主目录添加wx文件夹方式
    5. 同步更新微博官方分享支付(2018-6-22)
    6. 支持网络依赖
    7. 支持Instagram、Google、FaceBook、Twitter海外登录方式,调用方式一致

TODO

  • 支持多图分享
  • 支持视频分享

ChangeLog

2019-11-26

  • 分享添加分享开始回调

2019-05-30

  • 添加并测试成功Twitter登录

2019-05-29

  • 添加并测试成功Instagram登录
  • 添加并测试成功FaceBook登录
  • 添加并测试成功Google登录

2019-05-23

  • 更新支付宝支付(修改为aar依赖方式)
  • 去除登录、分享、支付所产生的内存泄漏

2018-12-3

  • 统一provider authorities方便多provider并存
  • authorities 必须为 包名.file.provider

2018-11-28

  • 修复分享、登录、支付引发的内存泄漏
  • 登录结果回调新增登录失败code
  • 修复7.0无法调用系统分享问题

2018-08-27

  • 抽离出gradle基础配置,方便调用时更改

2018-07-27

  • 修复微信支付成功无法获取回调

2018-07-12

  • 修复QQ分享无法获取成功回调

2018-07-11

  • 兼容安卓8.0

2018-06-22

  • 去除银联支付
  • 重写微博分享登录
  • 支持资源图片分享
  • 修改shareActivity为透明

2018-05-07

  • 添加微信支付、支付宝支付

2018-04-29

  • 修复小程序无法分享问题
  • qq_id置于shareutil包中,引用时直接修改该值
  • 暴露直接分享接口,分享过程需对图片进行二次处理(添加水印或其他处理),分享时直接传入处理后的图片,并调用直接分享方法

2018-02-07

  • 改用rxjava2库,支持小程序分享功能

ShareUtil

ShareUtil是一个综合性的分享及登录工具库, 支持微信分享,微博分享,QQ分享,QQ空间分享以及Android系统默认分享, 分纯文字、纯图片、图文混合(支持小程序分享)分享方式 支持微信登录,微博登录以及QQ登录并获取用户信息。

Feature

  1. 多种分享方式: 纯文字、纯图片、图文混合

  2. 支持分享图片本地链接,网络链接或者Bitmap, 不需要考虑各个平台的不一致性。

  3. 支持微信、QQ、微博登录并获取登录用户信息

  4. 支持小程序分享

  5. 混淆代码见 example module下 混淆文件

Usage

使用配置

使用方式

  1. 项目主module中 build.gradle 添加如下代码
    defaultConfig {
        ...
        // 必须配置qqid 否则无法获取分享成功回调
        // 注:以下三个参数均为占位,里面的值随意
        manifestPlaceholders = [
                qq_id: "1106618327"
                FACEBOOK_APP_ID: "1106618327",
                FACEBOOK_SCHEME: "1106618327"
        ]
        ...
    }

    api 'com.nfleo:ShareLoginPayUtil:1.1.2'
  1. 项目build.gradle 中添加如下代码
    buildscript {
        repositories {
            jcenter()
            maven { url "https://dl.bintray.com/thelasterstar/maven/" }
        }
    }

    allprojects {
        repositories {
            maven {url "https://maven.google.com"}
            google()

            // 微博 SDK 所需的配置
            maven { url "https://dl.bintray.com/thelasterstar/maven/" }

            // 支付宝 SDK AAR 包所需的配置
            flatDir {
                dirs '../shareutil/libs'
            }
            jcenter()
        }
    }

    ......

    // 所需版本可自行配置
    ext {
        compileSdkVersion = 27

        minSdkVersion = 21
        targetSdkVersion = 27
        supportVersion = "27.1.1"
    }
  1. 在使用之前设置在各个平台申请的Id,以及分享的回调(推荐放在Application的onCreate方法中)

         // init
         ShareConfig config = ShareConfig.instance()
                 .qqId(QQ_ID)
                 .wxId(WX_ID)
                 .weiboId(WEIBO_ID)
                 // 下面两个,如果不需要登录功能,可不填写
                 .weiboRedirectUrl(REDIRECT_URL)
                 .wxSecret(WX_ID);
         ShareManager.init(config);
    
         ** 系统分享图片必须添加以下两步
         1. 必须在AndroidManifest.xml添加 provider
         <!--兼容系统分享 7.0不支持uri跳转 必须使用content://替代-->
         <provider
             android:name="android.support.v4.content.FileProvider"
             android:authorities="${applicationId}.file.provider"  // 必须写成这个值
             android:exported="false"
             android:grantUriPermissions="true">
             <meta-data
                 android:name="android.support.FILE_PROVIDER_PATHS"
                 android:resource="@xml/file_paths" />
         </provider>
    
         2.res文件夹下创建xml文件夹,并在xml下创建file_paths.xml 文件名随便取
         注:分享图片保存地址为 /storage/emulated/0/Android/data/com.leo.project/files/share_image.jpg
         因此保存到 外部存储区域根目录下(使用 external-files-path)
         <paths xmlns:android="http://schemas.android.com/apk/res/android">
             <external-files-path name="name" path="" />
         </paths>
    

分享使用

    ShareUtil.shareImage(this, SharePlatform.QQ, "http://image.com", shareListener);
    ShareUtil.shareText(this, SharePlatform.WX, "分享文字", shareListener);
    ShareUtil.shareMedia(this, SharePlatform.QZONE, "title", "summary", "targetUrl", "thumb", shareListener);

    // miniId为小程序id    miniPath为小程序Path
    // 低版本微信不支持小程序分享, 此时默认网页分享方式
    ShareUtil.shareMedia(this, SharePlatform.WX, "title", "summary", "targetUrl", "thumb", "miniId", "miniPath", shareListener);

登录使用

        // LoginPlatform.WEIBO  微博登录   
        // LoginPlatform.WX     微信登录
        // LoginPlatform.QQ     QQ登录 
        final LoginListener listener = new LoginListener() {
                @Override
                public void loginSuccess(LoginResult result) {
                    //登录成功, 如果你选择了获取用户信息,可以通过
                }
            
                @Override
                public void loginFailure(Exception e) {
                    Log.i("TAG", "登录失败");
                }
    
                @Override
                public void loginCancel() {
                    Log.i("TAG", "登录取消");
                }
            };
        LoginUtil.login(MainActivity.this, LoginPlatform.WEIBO, mLoginListener, isFetchUserInfo);

支付使用

    // PayPlatform.ALIPAY   支付宝支付
    // PayPlatform.WXPAY    微信支付
    PayListener mPayListener = new PayListener() {
        @Override
        public void paySuccess() {
            Toast.makeText(v.getContext(), "支付成功", Toast.LENGTH_SHORT).show();
        }

        @Override
        public void payFailed(Exception e) {
            Toast.makeText(v.getContext(), "支付失败 " + e.getMessage(), Toast.LENGTH_SHORT).show();
        }

        @Override
        public void payCancel() {
            Toast.makeText(v.getContext(), "支付取消", Toast.LENGTH_SHORT).show();
        }
    };

    // 支付宝支付
    AliPayParamsBean payParamsBean = new AliPayParamsBean();
    payParamsBean.setOrderInfo("xxxx");
    PayUtil.pay(getContext(), PayPlatform.ALIPAY, payParamsBean, mPayListener);

    // 微信支付
    WXPayParamsBean wxPayParamsBean = new WXPayParamsBean();
    wxPayParamsBean.setAppid("xxxx");
    wxPayParamsBean.setNonceStr("xxxx");
    wxPayParamsBean.setPartnerid("xxxx");
    wxPayParamsBean.setPackageValue("xxxx");
    wxPayParamsBean.setPrepayId("xxxx");
    wxPayParamsBean.setSign("xxxx");
    wxPayParamsBean.setTimestamp("xxxx");
    PayUtil.pay(getContext(), PayPlatform.WXPAY, wxPayParamsBean, mPayListener);

使用说明

  1. QQ不支持纯文字分享,会直接分享失败

  2. 使用Jar文件的版本如下:

     微信版本:com.tencent.mm.opensdk:wechat-sdk-android-without-mta:5.1.4
     QQ版本:libs/open_sdk_r6008_lite.jar
     微博版本: com.sina.weibo.sdk:core:4.1.0:openDefaultRelease@aar
     支付宝版本: 'libs/alipaySdk-20180403.jar'
    
  3. 分享的bitmap,会在分享之后被回收掉,所以分享之后最好不要再对该bitmap做任何操作。

  4. ShareListener的回调结果仅供参考,不可当做分享是否返回的依据,它并不是那么完全可靠,因为某些操作,例如微博分享取消,但是用户选择了保存草稿,这时候客户端并不会收到回调,所以也就不会调用ShareListener的onCancel

Thanks

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].